

# Gowin Programmable IO (GPIO)

# **User Guide**

UG289-1.7E, 02/02/2021

#### Copyright© 2021 Guangdong Gowin Semiconductor Corporation. All Rights Reserved.

No part of this document may be reproduced or transmitted in any form or by any denotes, electronic, mechanical, photocopying, recording or otherwise, without the prior written consent of GOWINSEMI.

#### Disclaimer

GOWINSEMI®, LittleBee®, Arora, and the GOWINSEMI logos are trademarks of GOWINSEMI and are registered in China, the U.S. Patent and Trademark Office, and other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders, as described at www.gowinsemi.com. GOWINSEMI assumes no liability and provides no warranty (either expressed or implied) and is not responsible for any damage incurred to your hardware, software, data, or property resulting from usage of the materials or intellectual property except as outlined in the GOWINSEMI Terms and Conditions of Sale. All information in this document should be treated as preliminary. GOWINSEMI may make changes to this document at any time without prior notice. Anyone relying on this documentation should contact GOWINSEMI for the current documentation and errata.

# **Revision History**

| Date       | Version | Description                                                                                                                                 |  |
|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------|--|
| 05/17/2016 | 1.05E   | Initial version published.                                                                                                                  |  |
| 07/15/2016 | 1.06E   | The graphics standardized.                                                                                                                  |  |
| 08/02/2016 | 1.07E   | Supports GW2A series of FPGA Products Data Sheet                                                                                            |  |
| 10/27/2016 | 1.08E   | Supports GW2A series of FPGA Products Data Sheet                                                                                            |  |
| 09/01/2017 | 1.09E   | Features of GW1N-6/9 and GW1NR updated.                                                                                                     |  |
| 10/12/2017 | 1.10E   | IDES16/OSER16 related notes added.                                                                                                          |  |
| 12/12/2017 | 1.2E    | <ul> <li>IDDR/ODDR RESET signal removed;</li> <li>LVDS description updated;</li> <li>Input/output description with memory added.</li> </ul> |  |
| 04/08/2018 | 1.3E    | The chart in Chapter 7 updated.                                                                                                             |  |
| 05/14/2020 | 1.4E    | <ul><li>GPIO Primitive updated;</li><li>GW1N-6, GW1NR-6 devices deleted.</li></ul>                                                          |  |
| 08/27/2020 | 1.5E    | <ul> <li>The chapter structure modified.</li> <li>Chapter 4 Input/Output Logic and Chapter 5 IP Generation added.</li> </ul>                |  |
| 01/07/2021 | 1.6E    | IODELAYB added.                                                                                                                             |  |
| 02/02/2021 | 1.7E    | <ul> <li>The description of MIPI_IBUF_HS and MIPI_IBUF_LP added.</li> <li>GW2AN-55C and GW1NR-2 devices added.</li> </ul>                   |  |

i

# **Contents**

UG289-1.7E

|    | ontentsi                                            |
|----|-----------------------------------------------------|
| Li | st of Figuresiv                                     |
| Li | st of Tablesvi                                      |
| 1  | About This Guide1                                   |
|    | 1.1 Purpose                                         |
|    | 1.2 Related Documents1                              |
|    | 1.3 Terminology and Abbreviations2                  |
|    | 1.4 Support and Feedback2                           |
| 2  | <b>GPIO Overview3</b>                               |
| 3  | Input/Output Buffer5                                |
|    | 3.1 GPIO Level Standard5                            |
|    | 3.2 GPIO Banking                                    |
|    | 3.2.1 GW1N Series of FPGA Products8                 |
|    | 3.2.2 GW2A series of FPGA products9                 |
|    | 3.3 Power Supply Requirements                       |
|    | 3.3.1 LVCMOS Buffer Configuration                   |
|    | 3.3.2 Differential Buffer Configuration             |
|    | 3.4 Emulated Differential Circuit Matching Networks |
|    | 3.4.1 Emulated LVDS                                 |
|    | 3.4.2 Emulated LVPECL                               |
|    | 3.4.3 Emulated RSDS                                 |
|    | 3.4.4 Emulated BLVDS                                |
|    | 3.5 GPIO Software Configuration                     |
|    | 3.5.1 Location                                      |
|    | 3.5.2 Level Standard                                |
|    | 3.5.3 Drive Strength                                |
|    | 3.5.4 Pull Up/Pull Down                             |
|    | 3.5.5 Voltage Reference                             |
|    | 3.5.6 Hysteresis                                    |
|    | 3.5.7 Open Drain                                    |
|    | 3.5.8 Slew Rate                                     |

|     | 3.5.9 Termination Matching Resistors for Single-ended Signals  | . 13 |
|-----|----------------------------------------------------------------|------|
|     | 3.5.10 Termination Matching Resistors for Differential Signals | . 13 |
|     | 3.6 GPIO Primitive                                             | . 13 |
|     | 3.6.1 IBUF                                                     | . 14 |
|     | 3.6.2 OBUF                                                     | . 15 |
|     | 3.6.3 TBUF                                                     | . 16 |
|     | 3.6.4 IOBUF                                                    | . 17 |
|     | 3.6.5 LVDS Input Buffer                                        | . 18 |
|     | 3.6.6 LVDS Ouput Buffer                                        | . 20 |
|     | 3.6.7 LVDS Tristate Buffer                                     | . 22 |
|     | 3.6.8 LVDS Inout Buffer                                        | . 24 |
|     | 3.6.9 MIPI_IBUF                                                | . 25 |
|     | 3.6.10 MIPI_OBUF                                               | . 28 |
|     | 3.6.11 MIPI_OBUF_A                                             | . 30 |
|     | 3.6.12 I3C_IOBUF                                               | . 31 |
|     | 3.6.13 MIPI_IBUF_HS/MIPI_IBUF_LP                               | . 33 |
| 4 I | Input/Output Logic                                             | 36   |
|     | 4.1 SDR Mode                                                   | . 37 |
|     | 4.2 DDR Mode Input Logic                                       | . 37 |
|     | 4.2.1 IDDR                                                     | . 37 |
|     | 4.2.2 IDDRC                                                    | . 39 |
|     | 4.2.3 IDES4                                                    | . 41 |
|     | 4.2.4 IDES8                                                    | . 44 |
|     | 4.2.5 IDES10                                                   | . 47 |
|     | 4.2.6 IVIDEO                                                   | . 50 |
|     | 4.2.7 IDES16                                                   | . 53 |
|     | 4.2.8 IDDR_MEM                                                 | . 57 |
|     | 4.2.9 IDES4_MEM                                                | . 60 |
|     | 4.2.10 IDES8_MEM                                               | . 63 |
|     | 4.3 DDR Mode Output Logic                                      | . 67 |
|     | 4.3.1 ODDR                                                     | . 67 |
|     | 4.3.2 ODDRC                                                    | . 70 |
|     | 4.3.3 OSER4                                                    | . 73 |
|     | 4.3.4 OSER8                                                    | . 76 |
|     | 4.3.5 OSER10                                                   | . 80 |
|     | 4.3.6 OVIDEO                                                   | . 83 |
|     | 4.3.7 OSER16                                                   | . 86 |
|     | 4.3.8 ODDR_MEM                                                 | . 90 |
|     | 4.3.9 OSER4_MEM                                                | . 93 |

|   | 4.3.10 OSER8_MEM       | 98  |
|---|------------------------|-----|
|   | 4.4 Delay Module       | 103 |
|   | 4.4.1 IODELAY          |     |
|   | 4.4.2 IODELAYC         | 105 |
|   | 4.4.3 IODELAYB         | 108 |
|   | 4.5 IEM                | 111 |
| 5 | IP Generation          | 114 |
|   | 5.1 IP Configuration   | 114 |
|   | 5.2 IP Generated Files |     |

# **List of Figures**

| Figure 2-1 IOB Structure View                      | . 3  |
|----------------------------------------------------|------|
| Figure 3-1 Banking Arrangement in GW1N-4           | . 9  |
| Figure 3-2 Banking in GW2A series of FPGA Products | . 9  |
| Figure 3-3 LVDS25E Matching Network                | . 11 |
| Figure 3-4 LVPECL Matching Network                 | . 11 |
| Figure 3-5 RSDSE Matching Network                  | . 12 |
| Figure 3-6 BLVDS Matching Network                  | . 12 |
| Figure 3-7 IBUF Port Diagram                       | . 14 |
| Figure 3-8 OBUF Port Diagram                       | . 15 |
| Figure 3-9 TBUF Port Diagram                       | . 16 |
| Figure 3-10 IOBUF Port Diagram                     | . 17 |
| Figure 3-11 TLVDS_IBUF/ELVDS_IBUF Port Diagram     | . 18 |
| Figure 3-12 TLVDS_OBUF/ELVDS_OBUF Port Diagram     | . 20 |
| Figure 3-13 TLVDS_TBUF/ELVDS_TBUF Port Diagram     | . 22 |
| Figure 3-14 TLVDS_IOBUF/ELVDS_IOBUF Port Diagram   | . 24 |
| Figure 3-15 MIPI_IBUF Port Diagram                 | . 26 |
| Figure 3-16 MIPI_OBUF Port Diagram                 | . 29 |
| Figure 3-17 MIPI_OBUF_A Port Diagram               | . 30 |
| Figure 3-18 I3C_IOBUF Port Diagram                 | . 32 |
| Figure 3-19 MIPI_IBUF_HS/MIPI_IBUF_LP Port Diagram | . 33 |
| Figure 4-1 I/O Logic View-Output                   | . 36 |
| Figure 4-2 I/O Logic View-Input                    | . 37 |
| Figure 4-3 IDDR Logic Diagram                      | . 37 |
| Figure 4-4 IDDR Timing Diagram                     | . 38 |
| Figure 4-5 IDDR Port Diagram                       | . 38 |
| Figure 4-6 IDDRC Port Diagram                      | . 40 |
| Figure 4-7 CALIB Timing Diagram                    | . 42 |
| Figure 4-8 IDES4 Port Diagram                      | . 42 |
| Figure 4-9 IDES8 Port Diagram                      | . 45 |
| Figure 4-10 IDES10 Port Diagram                    | . 48 |
| Figure 4-11 IVIDEO Port Diagram                    | . 51 |
| Figure 4-12 IDES16 Port Diagram                    | . 54 |
|                                                    |      |

| Figure 4-13 IDDR_MEM Port Diagram   | 58  |
|-------------------------------------|-----|
| Figure 4-14 IDES4_MEM Port Diagram  | 61  |
| Figure 4-15 IDES8_MEM Port Diagram  | 64  |
| Figure 4-16 ODDR Logic Diagram      | 67  |
| Figure 4-17 ODDR Timing Diagram     | 68  |
| Figure 4-18 ODDR Port Diagram       | 68  |
| Figure 4-19 ODDRC Logic Diagram     | 70  |
| Figure 4-20 ODDRC Port Diagram      | 71  |
| Figure 4-21 OSER4 Logic Diagram     | 73  |
| Figure 4-22 OSER4 Port Diagram      | 73  |
| Figure 4-23 OSER8 Logic Diagram     | 77  |
| Figure 4-24 OSER8 Port Diagram      | 77  |
| Figure 4-25 OSER10 Port Diagram     | 81  |
| Figure 4-26 OVIDEO Port Diagram     | 84  |
| Figure 4-27 OSER16 Port Diagram     | 87  |
| Figure 4-28 ODDR_MEM Logic Diagram  | 90  |
| Figure 4-29 ODDR_MEM Port Diagram   | 91  |
| Figure 4-30 OSER4_MEM Logic Diagram | 94  |
| Figure 4-31 OSER4_MEM Diagram       | 94  |
| Figure 4-32 OSER8_MEM Logic Diagram | 98  |
| Figure 4-33 OSER8_MEM Port Diagram  | 99  |
| Figure 4-34 IODELAY Port Diagram    | 103 |
| Figure 4-35 IODELAYC Port Diagram   | 105 |
| Figure 4-36 IODELAYB Diagram        | 108 |
| Figure 4-37 IODELAYB Port Diagram   | 109 |
| Figure 4-38 IEM Port Diagram        | 112 |
| Figure 5-1 IP Customization of DDR  | 114 |

# **List of Tables**

| Table 1-1 Abbreviations and Terminology                | . 2  |
|--------------------------------------------------------|------|
| Table 3-1 Supported Output Level Standard and Options  | . 5  |
| Table 3-2 Supported Input Level Standard and Options   | . 7  |
| Table 3-3 IBUF Port Description                        | . 14 |
| Table 3-4 OBUF Port Description                        | . 15 |
| Table 3-5 TBUF Port Description                        | . 16 |
| Table 3-6 IOBUF Port Description                       | . 17 |
| Table 3-7 TLVDS_IBUF/ELVDS_IBUF Port Description       | . 18 |
| Table 3-8 TLVDS_OBUF/ELVDS_OBUF Port Description       | . 20 |
| Table 3-9 TLVDS_TBUF/ELVDS_TBUF Port Description       | . 22 |
| Table 3-10 TLVDS_IOBUF Devices Supported               | . 24 |
| Table 3-11 TLVDS_IOBUF/ELVDS_IOBUF Port Description    | . 24 |
| Table 3-12 MIPI_IBUF Devices Supported                 | . 26 |
| Table 3-13 MIPI_IBUF Port Description                  | . 26 |
| Table 3-14 MIPI_OBUF Devices Supported                 | . 28 |
| Table 3-15 MIPI_OBUF Port Description                  | . 29 |
| Table 3-16 MIPI_OBUF_A Port Description                | . 30 |
| Table 3-17 I3C_IOBUF Devices Supported                 | . 32 |
| Table 3-18 I3C_IOBUF Port Description                  | . 32 |
| Table 3-19 MIPI_IBUF_HS/MIPI_IBUF_LP Devices Supported | . 33 |
| Table 3-20 MIPI_IBUF_HS Port Description               | . 34 |
| Table 3-21 MIPI_IBUF_LP Port Description               | . 34 |
| Table 4-1 IDDR Port Description                        | . 38 |
| Table 4-2 IDDR Parameter Description                   | . 38 |
| Table 4-3 IDDRC Port Description                       | . 40 |
| Table 4-4 IDDRC Parameter Description                  | . 40 |
| Table 4-5 IDES4 Port Description                       | . 42 |
| Table 4-6 IDES4 Parameter Description                  | . 43 |
| Table 4-7 IDES8 Port Description                       | . 45 |
| Table 4-8 IDES8 Parameter Description                  | . 45 |
| Table 4-9 IDES10 Port Description                      | . 48 |
| Table 4-10 IDES10 Parameter Description                | . 48 |
|                                                        |      |

| Table 4-11 IVIDEO Port Description          | . 51  |
|---------------------------------------------|-------|
| Table 4-12 IVIDEO Parameter Description     | . 51  |
| Table 4-13 IDES16 Devices Supported         | . 53  |
| Table 4-14 IDES16 Port Description          | . 54  |
| Table 4-15 IDES10 Parameter Description     | . 54  |
| Table 4-16 IDDR_MEM Devices Supported       | . 57  |
| Table 4-17 IDDR_MEM Port Description        | . 58  |
| Table 4-18 IDDR_MEM Parameter Description   | . 58  |
| Table 4-19 IDES4_MEM Devices Supported      | . 60  |
| Table 4-20 IDES4_MEM Port Description       | . 61  |
| Table 4-21 IDES4_MEM Parameter Description  | . 61  |
| Table 4-22 IDES8_MEM Devices Supported      | . 63  |
| Table 4-23 IDES8_MEM Port Description       | . 64  |
| Table 4-24 IDES8_MEM Parameters Description | . 65  |
| Table 4-25 ODDR Port Description            | . 68  |
| Table 4-26 ODDR Parameter Description       | . 68  |
| Table 4-27 ODDRC Port Description           | . 71  |
| Table 4-28 ODDRC Parameter Description      | . 71  |
| Table 4-29 OSER4 Port Description           | . 74  |
| Table 4-30 IDES8_MEM Parameter Description  | . 74  |
| Table 4-31 OSER4 Port Description           | . 77  |
| Table 4-32 IDES8_MEM Parameter Description  | . 78  |
| Table 4-33 OSER10 Port Description          | . 81  |
| Table 4-34 OSER10 Parameter Description     |       |
| Table 4-35 OVIDEO Port Description          | . 84  |
| Table 4-36 OVIDEO Parameter Description     | . 84  |
| Table 4-37 OSER16 Devices Supported         | . 86  |
| Table 4-38 OSER16 Port Description          | . 87  |
| Table 4-39 OSER16 Parameter Description     | . 87  |
| Table 4-40 ODDR_MEM Devices Supported       | . 90  |
| Table 4-41 ODDR_MEM Port Description        | . 91  |
| Table 4-42 ODDR_MEM Parameter Description   | . 91  |
| Table 4-43 OSER4_MEM Devices Supported      | . 93  |
| Table 4-44 OSER4_MEM Port Description       | . 95  |
| Table 4-45 OSER4_MEM Parameter Description  | . 95  |
| Table 4-46 OSER8_MEM Devices Supported      | . 98  |
| Table 4-47 OSER4_MEM Port Description       | . 99  |
| Table 4-48 OSER4_MEM Parameter Description  | . 99  |
| Table 4-49 IODELAY Port Description         | . 103 |
| Table 4-50 IODELAY Parameter Description    | . 104 |

| Table 4-51 IODELAYC Devices Supported     | 105 |
|-------------------------------------------|-----|
| Table 4-52 IODELAYC Port Description      |     |
| Table 4-53 IODELAYC Parameter Description |     |
| Table 4-54 Devices Supported              | 108 |
| Table 4-55 IODELAYB Port Description      | 109 |
| Table 4-56 IODELAYB Parameter Description | 109 |
| Table 4-57 IEM Port Description           | 112 |
| Table 4-58 IFM Parameter Description      | 112 |

UG289-1.7E viii

1 About This Guide 1.1 Purpose

# 1 About This Guide

## 1.1 Purpose

Gowin Programmable IO (GPIO) User Guide provides descriptions of the level standard, banking scheme of the input/output buffer, and input/output logic functions supported by GOWINSEMI FPGA products. Gowin GPIO architecture and Gowin Software usage are also presented to provide you with a better understanding of the GPIO functions and rules.

#### 1.2 Related Documents

The latest user guides are available on the GOWINSEMI Website. You can find the related documents at <a href="https://www.gowinsemi.com">www.gowinsemi.com</a>:

- DS100, GW1N series of FPGA Products Data Sheet
- DS117, GW1NR series of FPGA Products Data Sheet
- DS821, GW1NS series of FPGA Products Data Sheet
- DS841, GW1NZ series of FPGA Products Data Sheet
- DS861, GW1NSR series of FPGA Products Data Sheet
- DS871, GW1NSE series of SecureFPGA Products Data Sheet
- DS881, GW1NSER series of SecureFPGA Products Data Sheet
- DS891, GW1NRF series of Bluetooth FPGA Products Data Sheet
- DS102, GW2A series of FPGA Products Data Sheet
- DS226, GW2AR series of FPGA Products Data Sheet
- DS961, GW2ANR series of FPGA Products Data Sheet
- DS971, GW2AN series of FPGA Products Data Sheet

UG289-1.7E 1(116)

# 1.3 Terminology and Abbreviations

Table 1-1 shows the abbreviations and terminology used in this manual.

Table 1-1 Abbreviations and Terminology

| Terminology and Abbreviations | Meaning                         |  |
|-------------------------------|---------------------------------|--|
| IOB                           | Input/Output Block              |  |
| I/O Buffer                    | Input/Output Buffer             |  |
| I/O Logic                     | Input/Output Logic              |  |
| CFU                           | Configurable Function Unit      |  |
| CRU                           | Configurable Routing Unit       |  |
| Slew Rate                     | Slew Rate                       |  |
| Bus Keeper                    | Bus Keeper                      |  |
| Open Drain                    | Open Drain                      |  |
| SDR                           | Single Data Rate                |  |
| DDR                           | Double Data Rate                |  |
| SER                           | Serializer                      |  |
| DES                           | Deserializer                    |  |
| TLDO                          | True LVDS Output                |  |
| ELDO                          | Emulated LVDS Output            |  |
| GPIO                          | Gowin Programmable Input/Output |  |

# 1.4 Support and Feedback

Gowin Semiconductor provides customers with comprehensive technical support. If you have any questions, comments, or suggestions, please feel free to contact us directly by the following ways.

Website: <a href="www.gowinsemi.com">www.gowinsemi.com</a>
E-mail: <a href="mailto:support@gowinsemi.com">support@gowinsemi.com</a>

UG289-1.7E 2(116)

# **2** GPIO Overview

Gowin GPIO meets a variety of I/O standards and supports both single-ended and differential level standards, providing an easy connection with external buses, storage devices, video applications, and other standards.

The basic blocks of the GPIO in the GOWINSEMI FPGA products are IOB, including I/O buffer, I/O logic, and the related programmable routing unit. The programmable routing unit is similar to the CRU in CFU.

As shown in Figure 2-1, each IOB contains two pins (A and B). They can be used as a differential pair or as a single-end input/output. The I/O buffer supports both single-ended and differential standards. The I/O logic supports deserializer, serializer, delay control, and byte alignment, and is suitable for high-speed data transmission. The programmable routing unit is used to connect I/O blocks and other on-chip resources.

Figure 2-1 IOB Structure View



UG289-1.7E 3(116)

The features of the input/output blocks in Gowin FPGA family are:

- V<sub>CCO</sub> is supplied based on bank.
- Supports LVCMOS, PCI, LVTTL, LVDS, SSTL, and HSTL.
- Some devices<sup>[1]</sup> support MIPI level standard and MIPI I3C OpenDrain/PushPull conversion.
- Supports input hysteresis option
- Supports output drive strength option
- Supports output slew rate option
- Supports individual bus keeper, pull-up/down resistor, and open drain output options
- Supports Hot Socket
- I/O logic supports SDR mode and DDR mode, etc.

#### Note!

[1]: For devices that support MIPI and I3C, please refer to the devices supported of 3.6.9, 3.6.10 and 3.6.12.

UG289-1.7E 4(116)

3 Input/Output Buffer 3.1 GPIO Level Standard

# 3 Input/Output Buffer

#### 3.1 GPIO Level Standard

GOWINSEMI FPGA products support both single-ended and differential standards. The single-ended standard can use built-in IO voltage as a reference voltage or any I/O voltage as an external reference voltage input. All banks in GOWINSEMI FPGA products support differential input. Emulated LVDS differential output is implemented by using external resistors and differential LVCMOS buffer output. For banks supporting true LVDS differential output and differential input matching, please refer to 3.2 GPIO Banking for more details.

Table 3-1 and Table 3-2 list the pin voltage requirements for the different level standards supported by GOWINSEMI FPGA products.

Table 3-1 Supported Output Level Standard and Options

| I/O output standard | Single-ended/differential | Bank V <sub>CCO</sub> (V) | Output Drive Strength (mA) |
|---------------------|---------------------------|---------------------------|----------------------------|
| LVTTL33             | Single-ended              | 3.3                       | 4,8,12,16,24               |
| LVCMOS33            | Single end                | 3.3                       | 4,8,12,16,24               |
| LVCMOS25            | Single end                | 2.5                       | 4,8, 12,16                 |
| LVCMOS18            | Single end                | 1.8                       | 4,8, 12                    |
| LVCMOS15            | Single end                | 1.5                       | 4,8                        |
| LVCMOS12            | Single end                | 1.2                       | 4,8                        |
| SSTL25_I            | Single end                | 2.5                       | 8                          |
| SSTL25_II           | Single end                | 2.5                       | 8                          |
| SSTL33_I            | Single end                | 3.3                       | 8                          |
| SSTL33_II           | Single end                | 3.3                       | 8                          |
| SSTL18_I            | Single end                | 1.8                       | 8                          |
| SSTL18_II           | Single end                | 1.8                       | 8                          |
| SSTL15              | Single end                | 1.5                       | 8                          |
| HSTL18_I            | Single end                | 1.8                       | 8                          |
| HSTL18_II           | Single end                | 1.8                       | 8                          |
| HSTL15_I            | Single end                | 1.5                       | 8                          |

UG289-1.7E 5(116)

3 Input/Output Buffer 3.1 GPIO Level Standard

| I/O output standard | Single-ended/differential | Bank V <sub>CCO</sub> (V) | Output Drive Strength (mA) |
|---------------------|---------------------------|---------------------------|----------------------------|
| PCI33               | Single end                | 3.3                       | N/A                        |
| LVPECL33E           | Differential              | 3.3                       | 16                         |
| MLVDS25E            | Differential              | 2.5                       | 16                         |
| BLVDS25E            | Differential              | 2.5                       | 16                         |
| RSDS25E             | Differential              | 2.5                       | 8                          |
| LVDS25E             | Differential              | 2.5                       | 8                          |
| LVDS25              | Differential              | 2.5                       | 1.25,2.0,2.5,3.5           |
| RSDS                | Differential              | 2.5/3.3                   | 2                          |
| MINILVDS            | Differential              | 2.5/3.3                   | 2                          |
| PPLVDS              | Differential              | 2.5/3.3                   | 3.5                        |
| SSTL15D             | Differential              | 1.5                       | 8                          |
| SSTL25D_I           | Differential              | 2.5                       | 8                          |
| SSTL25D_II          | Differential              | 2.5                       | 8                          |
| SSTL33D_I           | Differential              | 3.3                       | 8                          |
| SSTL33D_II          | Differential              | 3.3                       | 8                          |
| SSTL18D_I           | Differential              | 1.8                       | 8                          |
| SSTL18D_II          | Differential              | 1.8                       | 8                          |
| HSTL18D_I           | Differential              | 1.8                       | 8                          |
| HSTL18D_II          | Differential              | 1.8                       | 8                          |
| HSTL15D_I           | Differential              | 1.5                       | 8                          |
| LVCMOS12D           | Differential              | 1.2                       | 8,4                        |
| LVCMOS15D           | Differential              | 1.5                       | 8,4                        |
| LVCMOS18D           | Differential              | 1.8                       | 8,12, 4                    |
| LVCMOS25D           | Differential              | 2.5                       | 8,16, 12,4                 |
| LVCMOS33D           | Differential              | 3.3                       | 8,24,16,12,4               |
| MIPI                | Differential              | 1.2                       | 3.5                        |

UG289-1.7E 6(116)

3 Input/Output Buffer 3.1 GPIO Level Standard

Table 3-2 Supported Input Level Standard and Options

| I/O Input Standard | Single-ended/differential | Bank V <sub>CCO</sub> (V) | Hysteresis | Need V <sub>REF</sub> |
|--------------------|---------------------------|---------------------------|------------|-----------------------|
| LVTTL33            | Single-ended              | 3.3                       | Yes        | No                    |
| LVCMOS33           | Single end                | 3.3                       | Yes        | No                    |
| LVCMOS25           | Single end                | 2.5                       | Yes        | No                    |
| LVCMOS18           | Single end                | 1.8                       | Yes        | No                    |
| LVCMOS15           | Single end                | 1.5                       | Yes        | No                    |
| LVCMOS12           | Single end                | 1.2                       | Yes        | No                    |
| SSTL15             | Single end                | 1.5                       | No         | Yes                   |
| SSTL25_I           | Single end                | 2.5                       | No         | Yes                   |
| SSTL25_II          | Single end                | 2.5                       | No         | Yes                   |
| SSTL33_I           | Single end                | 3.3                       | No         | Yes                   |
| SSTL33_II          | Single end                | 3.3                       | No         | Yes                   |
| SSTL18_I           | Single end                | 1.8                       | No         | Yes                   |
| SSTL18_II          | Single end                | 1.8                       | No         | Yes                   |
| HSTL18_I           | Single end                | 1.8                       | No         | Yes                   |
| HSTL18_II          | Single end                | 1.8                       | No         | Yes                   |
| HSTL15_I           | Single end                | 1.5                       | No         | Yes                   |
| PCI33              | Single end                | 3.3                       | Yes        | No                    |
| LVCMOS33OD25       | Single end                | 2.5                       | No         | No                    |
| LVCMOS33OD18       | Single end                | 1.8                       | No         | No                    |
| LVCMOS33OD15       | Single end                | 1.5                       | No         | No                    |
| LVCMOS25OD18       | Single end                | 1.8                       | No         | No                    |
| LVCMOS25OD15       | Single end                | 1.5                       | No         | No                    |
| LVCMOS18OD15       | Single end                | 1.5                       | No         | No                    |
| LVCMOS150D12       | Single end                | 1.2                       | No         | No                    |
| LVCMOS25UD33       | Single end                | 3.3                       | No         | No                    |
| LVCMOS18UD25       | Single end                | 2.5                       | No         | No                    |
| LVCMOS18UD33       | Single end                | 3.3                       | No         | No                    |
| LVCMOS15UD18       | Single end                | 1.8                       | No         | No                    |
| LVCMOS15UD25       | Single end                | 2.5                       | No         | No                    |
| LVCMOS15UD33       | Single end                | 3.3                       | No         | No                    |
| LVCMOS12UD15       | Single end                | 1.5                       | No         | No                    |
| LVCMOS12UD18       | Single end                | 1.8                       | No         | No                    |
| LVCMOS12UD25       | Single end                | 2.5                       | No         | No                    |
| LVCMOS12UD33       | Single end                | 3.3                       | No         | No                    |
| LVDS25             | Differential              | 2.5                       | No         | No                    |
| RSDS               | Differential              | 2.5/3.3                   | No         | No                    |
| MINILVDS           | Differential              | 2.5/3.3                   | No         | No                    |
| PPLVDS             | Differential              | 2.5/3.3                   | No         | No                    |

UG289-1.7E 7(116)

3 Input/Output Buffer 3.2 GPIO Banking

| I/O Input Standard | Single-ended/differential | Bank V <sub>CCO</sub> (V) | Hysteresis | Need V <sub>REF</sub> |
|--------------------|---------------------------|---------------------------|------------|-----------------------|
| LVDS25E            | Differential              | 2.5                       | No         | No                    |
| MLVDS25E           | Differential              | 2.5                       | No         | No                    |
| BLVDS25E           | Differential              | 2.5                       | No         | No                    |
| RSDS25E            | Differential              | 2.5                       | No         | No                    |
| LVPECL33E          | Differential              | 3.3                       | No         | No                    |
| SSTL15D            | Differential              | 1.5                       | No         | No                    |
| SSTL25D_I          | Differential              | 2.5                       | No         | No                    |
| SSTL25D_II         | Differential              | 2.5                       | No         | No                    |
| SSTL33D_I          | Differential              | 3.3                       | No         | No                    |
| SSTL33D_II         | Differential              | 3.3                       | No         | No                    |
| SSTL18D_I          | Differential              | 1.8                       | No         | No                    |
| SSTL18D_II         | Differential              | 1.8                       | No         | No                    |
| HSTL18D_I          | Differential              | 1.8                       | No         | No                    |
| HSTL18D_II         | Differential              | 1.8                       | No         | No                    |
| HSTL15D_I          | Differential              | 1.5                       | No         | No                    |
| LVCMOS12D          | Differential              | 1.2                       | No         | No                    |
| LVCMOS15D          | Differential              | 1.5                       | No         | No                    |
| LVCMOS18D          | Differential              | 1.8                       | No         | No                    |
| LVCMOS25D          | Differential              | 2.5                       | No         | No                    |
| LVCMOS33D          | Differential              | 3.3                       | No         | No                    |
| MIPI               | Differential              | 1.2                       | No         | No                    |

# 3.2 GPIO Banking

The generic attributes of GPIO are:

- All banks support emulated LVDS differential output using external resistance;
- All banks support pull up, pull down, and bus-keeper settings;
- Each bank supports one kind of pin voltage;
- Each bank supports one reference voltage signal, whether it is from an external pin or from the internal reference voltage generator.

This manual takes GW1N and GW2A series of devices as examples to introduce the GPIO banking of Gowin FPGA products. For other series devices, please refer to the corresponding product datasheet.

#### 3.2.1 GW1N Series of FPGA Products

The GW1N series of FPGA products bank is introduced using the GW1N-4 device as an example, as shown in Figure 3-1. The GW1N series of FPGA products has four banks. Each bank has independent  $V_{cco}$ , and  $V_{cco}$  can be configured as 3.3V, 2.5V, 1.8V, 1.5V, or 1.2V. For the banking rules of other GW1N series devices, please refer to the "I/O Level Standards" section in DS100, GW1N series of FPGA product datasheet.

UG289-1.7E 8(116)

3 Input/Output Buffer 3.2 GPIO Banking

Figure 3-1 Banking Arrangement in GW1N-4



BANK1/2/3 in GW1N series of FPGA products supports true LVDS differential output driving. Bank0 supports internal  $100\Omega$  input differential matched resistance. The top bank of the GW1N-9 and GW1N-9C devices supports MIPI input and the bottom bank supports MIPI output.

#### 3.2.2 GW2A series of FPGA products

The GW2A series of FPGA Products has eight banks. Each bank has independent  $V_{cco}$ , and  $V_{cco}$  can be configured as 3.3V, 2.5V, 1.8V, 1.5V, or 1.2V.

Figure 3-2 Banking in GW2A series of FPGA Products



All Banks in the GW2A series of FPGA Products support true LVDS output; Bank0/1 supports  $100\Omega$  input differential matched resistance.

UG289-1.7E 9(116)

## 3.3 Power Supply Requirements

GOWINSEMI FPGA products can be powered and operated when  $V_{\text{CC}}$  and  $V_{\text{CCO}}$  reach a certain threshold and POR is set. By default, the GPIO is tristate input weak pull-up for blank chips. There are no power-on and power-off sequence requirements for core voltage and pin voltage for GOWINSEMI FPGA products.

Each bank supports one reference voltage input ( $V_{REF}$ ). Any I/O in one Bank can be configured as an input reference voltage. To support SSTL and HSTL, the reference voltage can be set as half of the I/O voltage. The input reference voltage can also be generated by the internal reference voltage generator. The internal reference voltage generator and the external reference voltage cannot be effective at the same time because each bank has only one reference voltage.

The GOWINSEMI FPGA GPIO includes two input/output pins, marked as A and B respectively. Pin A corresponds to the T (True) of the differential pair, and Pin B corresponds to the C (Comp) of the differential pair.

#### 3.3.1 LVCMOS Buffer Configuration

All GPIOs contain LVCMOS buffers. These LVCMOS buffers can be configured in a variety of modes to support different applications. Each LVCMOS buffer can be configured as weak pull-up, weak pull-down, and bus-keeper. The pull-up and pull-down offer a fixed characteristic, which is useful when creating wired logic such as wired ORs. The bus-keeper latches the signal in the last driven state, holding it at a valid level with minimal power consumption. Input leakage can be reduced by turning off the bus-hold circuit.

All LVCMOS buffers have programmable drive strength. Please refer to Table 3-1 for the detailed drive strength of different IO standards. The drive strength of GOWINSEMI FPGA products is guaranteed with minimum drive strength for each drive setting.

The de-hysteresis setting is used to prevent quick successive changes of levels in a noisy environment. All LVCMOS buffers support the de-hysteresis setting.

The slew rate setting takes effect at both the rising edge and the falling edges. The LVCMOS buffer can be configured for either low noise (SLOW) or high speed performance (FAST).

When a differential pair is configured as two single-ended pins, the relative delay between the two pins is maintained at a minimum, and the signal consistency is the best.

#### 3.3.2 Differential Buffer Configuration

When a GPIO buffer is configured as a differential receiver, the input de-hysteresis and bus-hold will be disabled for the buffer.

BANK0 in GW1N devices supports on-chip programmable 100 Ohm input differential matched resistance. Figure 3-1 shows the bank distribution of GW1N devices.

UG289-1.7E 10(116)

BANK0/1 in GW2A devices supports on-chip programmable 100 Ohm input differential matched resistance. Figure 3-2 shows the bank distribution of GW2A devices.

All the single-ended GPIO buffer pairs can be configured to support emulated LVDS differential output standards, such as LVPECL33E, MLVDS25E, BLVDS25E, etc. An off-chip impedance matching network is also required.

BANK1/2/3 in GW1N devices supports true LVDS differential output driving.

All BANKs in GW2A devices support true LVDS differential output driving.

## 3.4 Emulated Differential Circuit Matching Networks

#### 3.4.1 Emulated LVDS

GOWINSEMI FPGA products can build compatible LVCMOS output standards via the complementary LVCMOS output and external matching network. Figure 3-3 shows the external matching network.

Figure 3-3 LVDS25E Matching Network



#### 3.4.2 Emulated LVPECL

GOWINSEMI FPGA products can build compatible LVPECL output standards via the complementary LVCMOS output and external matching network. Figure 3-4 shows the external matching network.

Figure 3-4 LVPECL Matching Network



#### 3.4.3 Emulated RSDS

GOWINSEMI FPGA products can build compatible RSDS output standards via the complementary LVCMOS output and external matching network. Figure 3-5 shows the external matching network.

UG289-1.7E 11(116)

**Figure 3-5 RSDSE Matching Network** 



#### 3.4.4 Emulated BLVDS

GOWINSEMI FPGA products can build compatible BLVDS output standards via the complementary LVCMOS output and external matching network. Figure 3-6 shows the external matching network.

Figure 3-6 BLVDS Matching Network



# 3.5 GPIO Software Configuration

You can set GPIO location, attributes, etc. through Floorplanner in Gowin Software, or you can customize the CST file to achieve this. The following is a detailed description of the physical constraints supported by CST files.

#### 3.5.1 Location

Lock the physical location of GPIO:

IO\_LOC "xxx" H4 exclusive;

#### 3.5.2 Level Standard

Set the level standard for GPIO:

IO\_PORT "xxx" IO\_TYPE=LVCMOS18D;

UG289-1.7E 12(116)

#### 3.5.3 Drive Strength

Set the drive strength of output pins or IO pins:

IO\_PORT "xxx" DRIVE=12;

#### 3.5.4 Pull Up/Pull Down

Set pull up/down modes, such as UP (pull-up), DOWN (pull down), KEEPER (bus-hold), and NONE (high impedance).

IO\_PORT "xxx" PULL\_MODE=DOWN;

#### 3.5.5 Voltage Reference

Set reference voltage for GPIO. The reference voltage can be from external pins or internal reference voltage generator.

IO\_PORT "xxx" VREF=VREF1\_LOAD;

#### 3.5.6 Hysteresis

Set the hysteresis value for input pins or bidirectional IO pins. The value is NONE, H2L, L2H, HIGH from small to large in sequence.

IO\_PORT "xxx" HYSTERESIS=L2H;

#### 3.5.7 Open Drain

Open Drain is available for both output and bidirectional IO pins. The values are ON and OFF.

IO\_PORT "xxx" OPEN\_DRAIN=ON;

#### 3.5.8 Slew Rate

Specify slew rate for output pins or bidirectional IO pins. SLOW: low noise mode. FAST: high speed mode.

IO PORT "xxx" SLEW\_RATE=SLOW;

### 3.5.9 Termination Matching Resistors for Single-ended Signals

Set termination matching resistors for single-ended signals. The values are OFF and 100 ohm.

IO\_PORT "xxx" SINGLE\_RESISTOR=100;

#### 3.5.10 Termination Matching Resistors for Differential Signals

Set termination matching resistors for differential signals. The values are OFF and 100 ohm.

IO PORT "xxx" Diff RESISTOR=100;

#### 3.6 GPIO Primitive

IO Buffer with buffer function includes normal buffer, emulated LVDS, and true LVDS.

UG289-1.7E 13(116)

#### 3.6.1 IBUF

#### **Primitive Introduction**

Input Buffer (IBUF)

#### **Port Diagram**

Figure 3-7 IBUF Port Diagram



#### **Port Description**

**Table 3-3 IBUF Port Description** 

| Ports | I/O    | Description        |
|-------|--------|--------------------|
| I     | Input  | Data Input Signal  |
| 0     | Output | Data Output Signal |

#### **Primitive Instantiation**

#### **Verilog Instantiation:**

```
IBUF uut(
     .O(O),
     .l(l)
);
```

```
Vhdl Instantiation:
  COMPONENT IBUF
      PORT (
            O:OUT std_logic;
            I:IN std_logic
      );
  END COMPONENT;
  uut:IBUF
        PORT MAP (
          O=>O,
          |=>|
       );
```

UG289-1.7E 14(116)

#### 3.6.2 **OBUF**

#### **Primitive Introduction**

Output Buffer (OBUF).

#### **Port Diagram**

**Figure 3-8 OBUF Port Diagram** 



#### **Port Description**

#### **Table 3-4 OBUF Port Description**

| Ports | I/O    | Description        |
|-------|--------|--------------------|
| I     | Input  | Data Input Signal  |
| 0     | Output | Data Output Signal |

#### **Primitive Instantiation**

#### **Verilog Instantiation:**

```
OBUF uut(
.O(O),
.I(I)
);
```

#### **VhdI Instantiation:**

```
COMPONENT OBUF
```

```
PORT (
O:OUT std_logic;
I:IN std_logic
);
END COMPONENT;
uut:OBUF
PORT MAP (
O=>O,
I=>I
);
```

UG289-1.7E 15(116)

#### 3.6.3 TBUF

#### **Primitive Introduction**

Output Buffer with Tristate Control (TBUF), active-low.

#### **Port Diagram**

Figure 3-9 TBUF Port Diagram



#### **Port Description**

**Table 3-5 TBUF Port Description** 

| Ports | I/O    | Description                   |
|-------|--------|-------------------------------|
| 1     | Input  | Data Input Signal             |
| OEN   | Input  | Output Tristate Enable Signal |
| 0     | Output | Data Output Signal            |

#### **Primitive Instantiation**

#### **Verilog Instantiation:**

```
TBUF uut(
.O(O),
.I(I),
.OEN(OEN)
);

VhdI Instantiation:

COMPONENT TBUF
PORT (
O:OUT std_logic;
I:IN std_logic;
```

);

**END COMPONENT;** 

UG289-1.7E 16(116)

OEN:IN std\_logic

```
uut:TBUF

PORT MAP (

O=>O,

I=>I,

OEN=>OEN

);
```

#### **3.6.4 IOBUF**

#### **Primitive Introduction**

Bi-Directional Buffer (IOBUF) is used as an input buffer when OEN is high and is used as an output buffer when ONE is low.

#### **Port Diagram**

Figure 3-10 IOBUF Port Diagram



#### **Port Description**

**Table 3-6 IOBUF Port Description** 

| Ports | I/O    | Description                             |
|-------|--------|-----------------------------------------|
| 1     | Input  | Data Input Signal                       |
| OEN   | Input  | Output Tristate Enable Signal           |
| Ю     | Inout  | Input and output signals, bidirectional |
| 0     | Output | Data Output Signal                      |

#### **Primitive Instantiation**

#### **Verilog Instantiation:**

#### **VhdI Instantiation:**

**COMPONENT IOBUF** 

UG289-1.7E 17(116)

```
PORT (
O:OUT std_logic;
IO:INOUT std_logic;
I:IN std_logic;
OEN:IN std_logic
);
END COMPONENT;
uut:IOBUF
PORT MAP (
O=>O,
IO=>IO,
I=>I,
OEN=>OEN
);
```

#### 3.6.5 LVDS Input Buffer

#### **Primitive Introduction**

The LVDS includes TLVDS\_IBUF and ELVDS\_IBUF.
True LVDS Input Buffer (TLVDS\_IBUF).

#### Note!

The devices of GW1NZ-1 and GW1N-1S do not support TLVDS\_IBUF.

Emulated LVDS Input Buffer (ELVDS\_IBUF).

#### Note!

The device of GW1NZ-1 does not support ELVDS\_IBUF.

#### **Port Diagram**

Figure 3-11 TLVDS\_IBUF/ELVDS\_IBUF Port Diagram



#### **Port Description**

Table 3-7 TLVDS\_IBUF/ELVDS\_IBUF Port Description

| Ports | I/O    | Description                      |
|-------|--------|----------------------------------|
| I     | Input  | Differential Input A-side Signal |
| IB    | Input  | Differential Input B-side Signal |
| 0     | Output | Data Output Signal               |

UG289-1.7E 18(116)

# Example One **Verilog Instantiation:** TLVDS\_IBUF uut( .O(O), .l(l), .IB(IB) ); **VhdI Instantiation:** COMPONENT TLVDS\_IBUF PORT ( O:OUT std\_logic; I:IN std\_logic; IB:IN std\_logic ); **END COMPONENT;** uut:TLVDS\_IBUF PORT MAP( O=>O, I=>I, IB=>IB ); **Example Two Verilog Instantiation:** ELVDS\_IBUF uut( .O(O), .l(l), .IB(IB) ); **VhdI Instantiation:** COMPONENT ELVDS\_IBUF PORT ( O:OUT std\_logic; I:IN std\_logic; IB:IN std\_logic

**Primitive Instantiation** 

UG289-1.7E 19(116)

```
);
END COMPONENT;
uut:ELVDS_IBUF
PORT MAP(
O=>O,
I=>I,
IB=>IB
):
```

#### 3.6.6 LVDS Ouput Buffer

#### **Primitive Introduction**

LVDS includes TLVDS\_OBUF and ELVDS\_OBUF.

True LVDS Output Buffer (TLVDS\_OBUF) .

#### Note!

The devices of GW1N-1, GW1NR-1, GW1NZ-1 and GW1N-1S do not support TLVDS OBUF.

Emulated LVDS Output Buffer (ELVDS\_OBUF).

#### **Port Diagram**

Figure 3-12 TLVDS\_OBUF/ELVDS\_OBUF Port Diagram



#### **Port Description**

Table 3-8 TLVDS\_OBUF/ELVDS\_OBUF Port Description

| Ports | I/O    | Description                       |
|-------|--------|-----------------------------------|
| 1     | Input  | Data Input Signal                 |
| ОВ    | Output | B-side Differential Output Signal |
| 0     | Output | A-side Differential Output Signal |

#### **Primitive Instantiation**

Example One

#### **Verilog Instantiation:**

```
TLVDS_IBUF uut(
.O(O),
.OB(OB),
```

UG289-1.7E 20(116)

```
.l(l)
  );
VhdI Instantiation:
  COMPONENT TLVDS_OBUF
      PORT (
            O:OUT std_logic;
             OB:OUT std_logic;
             I:IN std_logic
      );
  END COMPONENT;
  uut:TLVDS_OBUF
        PORT MAP(
          O = > O,
           OB=>OB,
           I=> I
       );
  Example Two
Verilog Instantiation:
  ELVDS_OBUF uut(
      .O(O),
      .OB(OB),
      .l(l)
  );
VhdI Instantiation:
  COMPONENT ELVDS_OBUF
      PORT (
            O:OUT std_logic;
             OB:OUT std_logic;
             I:IN std_logic
      );
  END COMPONENT;
  uut:ELVDS_OBUF
         PORT MAP(
           O=>O,
            OB=>OB,
```

UG289-1.7E 21(116)

```
l=> l
);
```

#### 3.6.7 LVDS Tristate Buffer

#### **Primitive Introduction**

LVDS tristate buffer includes TLVDS\_TBUF and ELVDS\_TBUF. True LVDS Tristate Buffer (TLVDS\_TBUF) is active-low.

#### Note!

The devices of GW1N-1, GW1NR-1, GW1NZ-1 and GW1N-1S do not support TLVDS\_TBUF.

Emulated LVDS Tristate Buffer (ELVDS\_TBUF), active-low

#### **Port Diagram**

Figure 3-13 TLVDS\_TBUF/ELVDS\_TBUF Port Diagram



#### **Port Description**

#### Table 3-9 TLVDS\_TBUF/ELVDS\_TBUF Port Description

| Ports | I/O    | Description                       |
|-------|--------|-----------------------------------|
| 1     | Input  | Data Input Signal                 |
| OEN   | Input  | Output Tristate Enable Signal     |
| ОВ    | Output | B-side Differential Output Signal |
| 0     | Output | A-side Differential Output Signal |

#### **Primitive Instantiation**

**Example One** 

#### **Verilog Instantiation:**

```
TLVDS_TBUF uut(
.O(O),
.OB(OB),
.I(I),
.OEN(OEN)
);
```

#### **VhdI Instantiation:**

```
COMPONENT TLVDS_TBUF
PORT (
```

UG289-1.7E 22(116)

```
O:OUT std_logic;
             OB:OUT std_logic;
             I:IN std_logic;
             OEN:IN std_logic
      );
  END COMPONENT;
  uut:TLVDS_TBUF
         PORT MAP(
           O=>O,
            OB=>OB,
            l=>1
            OEN=>OEN
        );
  Example Two
Verilog Instantiation:
  ELVDS_TBUF uut(
    .O(O),
    .OB(OB),
    .l(I),
    .OEN(OEN)
  );
VhdI Instantiation:
  COMPONENT ELVDS_TBUF
      PORT (
            O:OUT std_logic;
             OB:OUT std_logic;
             I:IN std_logic;
             OEN:IN std_logic
      );
  END COMPONENT;
  uut:ELVDS_TBUF
         PORT MAP(
           O=>O,
            OB=>OB,
            I=> I,
```

UG289-1.7E 23(116)

# OEN=>OEN

#### 3.6.8 LVDS Inout Buffer

#### **Primitive Introduction**

);

The LVDS inout buffer includes TLVDS\_IOBUF and ELVDS\_IOBUF.

True LVDS Bi-Directional Buffer (TLVDS\_IOBUF) is used as true differential input buffer when OEN is high and used as true differential output buffer when OEN is low.

#### **Devices Supported**

Table 3-10 TLVDS\_IOBUF Devices Supported

| Product Family         | Series | Device                               |
|------------------------|--------|--------------------------------------|
|                        | GW2A   | GW2A-18, GW2A-18C, GW2A-55, GW2A-55C |
| Arora                  | GW2AN  | GW2AN-55C                            |
| Aloia                  | GW2AR  | GW2AR-18,GW2AR-18C                   |
|                        | GW2ANR | GW2ANR-18C                           |
|                        | GW1N   | GW1N-4, GW1N-4B, GW1N-4C             |
| LittleBee <sup>®</sup> | GW1NR  | GW1NR-4, GW1NR-4B, GW1NR-4C          |
|                        | GW1NRF | GW1NRF-4B                            |

ELVDS\_IOBUF is used as emulated differential input buffer when OEN is high and used as emulated differential output buffer when OEN is low.

#### Note

The GW1NZ-1 devices do not support ELVDS\_IOBUF.

#### **Port Diagram**

Figure 3-14 TLVDS\_IOBUF/ELVDS\_IOBUF Port Diagram



#### **Port Description**

Table 3-11 TLVDS\_IOBUF/ELVDS\_IOBUF Port Description

| Ports | I/O    | Description                      |
|-------|--------|----------------------------------|
| I     | Input  | Data Input Signal                |
| OEN   | Input  | Output Tristate Enable Signal    |
| 0     | Output | Data Output Signal               |
| IOB   | Inout  | B-side Differential Input/Output |
| Ю     | Inout  | A-side Differential Input/Output |

UG289-1.7E 24(116)

#### **Primitive Instantiation**

```
Verilog Instantiation:
```

```
ELVDS_IOBUF uut(
    .O(O),
    .IO(IO),
    .IOB(IOB),
    .l(I),
    .OEN(OEN)
  );
VhdI Instantiation:
  COMPONENT ELVDS_IOBUF
      PORT (
            O:OUT std_logic;
             IO:INOUT std_logic;
             IOB:INOUT std_logic;
             I:IN std_logic;
             OEN:IN std_logic
      );
  END COMPONENT;
  uut:ELVDS_IOBUF
         PORT MAP(
           O = > O,
            IO=>IO,
            IOB=>IOB,
            I=> I,
            OEN=>OEN
        );
```

#### 3.6.9 MIPI\_IBUF

#### **Primitive Introduction**

MIPI Input Buffer (MIPI\_IBUF) includes HS input mode and LP bi-direction mode, and HS mode supports dynamic resistance configuration.

UG289-1.7E 25(116)

## **Devices Supported**

Table 3-12 MIPI\_IBUF Devices Supported

| Product Family         | Series  | Device                                      |
|------------------------|---------|---------------------------------------------|
|                        | GW1N    | GW1N-9,GW1N-9C, GW1N-2                      |
|                        | GW1NR   | GW1NR-9,GW1NR-9C, GW1NR-2                   |
|                        | GW1NS   | GW1NS-2, GW1NS-2C, GW1NS-4, GW1NS-4C        |
| LittleBee <sup>®</sup> | GW1NZ   | GW1NZ-2                                     |
|                        | GW1NSE  | GW1NSE-2C                                   |
|                        | GW1NSER | GW1NSER-4C                                  |
|                        | GW1NSR  | GW1NSR-2, GW1NSR-2C, GW1NSR-4,<br>GW1NSR-4C |

## **Functional Description**

MIPI\_IBUF supports LP and HS mode. IO and IOB are connected to pad.

LP mode: Supports bi-directional. When OEN is low, I is input and IO is output; when OEN is high, IO is input and OL is output; when OENB is low, IB is input and IOB is output; when OENB is high, IOB is input and OB is output.

HS mode: IO and IOB are the differential inputs. OH is the output, then HSREN controls the termination resistor.

## **Port Diagram**

Figure 3-15 MIPI\_IBUF Port Diagram



## **Port Description**

Table 3-13 MIPI\_IBUF Port Description

| Ports | I/O    | Description                                        |
|-------|--------|----------------------------------------------------|
| 1     | Input  | In LP mode, I is the input when OEN is low.        |
| IB    | Input  | In LP mode, IB is the input when OENB is low.      |
| HSREN | Input  | In HS mode, controls termination resistor.         |
| OEN   | Input  | In LP mode, inputs/outputs tristate control signal |
| OENB  | Input  | In LP mode, inputs/outputs tristate control signal |
| ОН    | Output | In HS mode, data output signal                     |

UG289-1.7E 26(116)

| Ports | I/O    | Description                                                                                                                           |  |
|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------|--|
| OL    | Output | In LP mode, OL is the output when OEN is high.                                                                                        |  |
| ОВ    | Output | In LP mode, OB is the output when OENB is high.                                                                                       |  |
| Ю     | Inout  | <ul> <li>In LP mode, IO is output when OEN is low and input when OEN is high;</li> <li>In HS mode, IO is input.</li> </ul>            |  |
| IOB   | Inout  | <ul> <li>In LP mode, IOB is output when OENB is low and IOB is input when OENB is high;</li> <li>In HS mode, IOB is input.</li> </ul> |  |

#### **Primitive Instantiation**

## **Verilog Instantiation:**

```
MIPI_IBUF uut(
     .OH(OH),
     .OL(OL),
     .OB(OB),
     .IO(IO),
     .IOB(IOB),
     .I(I),
     .IB(IB),
     .OEN(OEN),
     .OENB(OENB),
     HSREN(HSREN)
  );
VhdI Instantiation:
  COMPONENT MIPI_IBUF
      PORT (
        OH:OUT std_logic;
        OL: OUT std_logic;
        OB:OUT std_logic;
        IO:INOUT std_logic;
            IOB:INOUT std_logic;
            I:IN std_logic;
        IB:IN std_logic;
             OEN:IN std_logic;
        OENB:IN std_logic;
        HSREN: IN std_logic
```

UG289-1.7E 27(116)

```
);
END COMPONENT;
uut: MIPI_IBUF
PORT MAP(
OH=>OH,
OL=>OL,
OB=>OB,
IO=>IO,
IOB=>IOB,
I=> I,
IB=>IB,
OEN=>OEN,
OENB=>OENB,
HSREN=>HSREN
```

# **3.6.10 MIPI\_OBUF**

#### **Primitive Introduction**

MIPI Output Buffer (MIPI\_OBUF) includes HS mode and LP mode.

MIPI\_OBUF is used as (HS) MIPI output buffer when MODESEL is high and used as (LP) MIPI output buffer when MODESEL is low.

# **Devices Supported**

Table 3-14 MIPI\_OBUF Devices Supported

| Product Family         | Series  | Device                                      |
|------------------------|---------|---------------------------------------------|
|                        | GW1N    | GW1N-9,GW1N-9C, GW1N-2                      |
|                        | GW1NR   | GW1NR-9,GW1NR-9C,GW1NR-2                    |
|                        | GW1NS   | GW1NS-2, GW1NS-2C, GW1NS-4, GW1NS-4C        |
| LittleBee <sup>®</sup> | GW1NZ   | GW1NZ-2                                     |
|                        | GW1NSE  | GW1NSE-2C                                   |
|                        | GW1NSER | GW1NSER-4C                                  |
|                        | GW1NSR  | GW1NSR-2, GW1NSR-2C, GW1NSR-4,<br>GW1NSR-4C |

UG289-1.7E 28(116)

## **Port Diagram**

## Figure 3-16 MIPI\_OBUF Port Diagram



## **Port Description**

Table 3-15 MIPI\_OBUF Port Description

| Ports   | I/O    | Description                                                                                     |  |
|---------|--------|-------------------------------------------------------------------------------------------------|--|
| 1       | Input  | A-ended data input signal for HS mode or LP mode                                                |  |
| IB      | Input  | B-ended data input signal in LP mode                                                            |  |
| MODESEL | Input  | Mode selection signal, HS or LP mode                                                            |  |
| 0       | Output | A-ended data output signal, A differential output in HS mode, A single-ended output in LP mode. |  |
| ОВ      | Output | B-ended data output signal, B differential output in HS mode, B single-ended output in LP mode. |  |

#### **Primitive Instantiation**

## **Verilog Instantiation:**

```
MIPI_OBUF uut(
    .O(O),
    .OB(OB),
    .l(I),
    .IB(IB),
    .MODESEL(MODESEL)
  );
VhdI Instantiation:
  COMPONENT MIPI_OBUF
      PORT (
         O:OUT std_logic;
         OB:OUT std_logic;
             I:IN std_logic;
             IB:IN std_logic;
         MODESEL: IN std_logic
      );
  END COMPONENT;
  uut: MIPI_OBUF
```

UG289-1.7E 29(116)

```
PORT MAP(
    O=>O,

OB=>OB,
    I=> I,
    IB=>IB,

MDOESEL=>MODESEL
);
```

## 3.6.11 MIPI OBUF A

#### **Primitive Introduction**

MIPI OBUF A includes HS mode and LP mode.

MIPI Output Buffer with IL Signal (MIPI\_OBUF\_A) is used as (HS) MIPI output buffer when MODESEL is high and used as (LP) MIPI output buffer when MODESEL is low. The difference with MIPI\_OBUF is the addition of the IL port as an A input in LP mode.

## **Devices Supported**

For the devices supported by MIPI\_OBUF\_A, please see Table 3-14.

#### **Port Diagram**

Figure 3-17 MIPI\_OBUF\_A Port Diagram



#### **Port Description**

Table 3-16 MIPI\_OBUF\_A Port Description

| Ports   | I/O    | Description                                                                                     |
|---------|--------|-------------------------------------------------------------------------------------------------|
| 1       | Input  | A-ended data input signal in HS mode                                                            |
| IB      | Input  | B-ended data input signal in LP mode                                                            |
| IL      | Input  | A-ended data input signal in LP mode                                                            |
| MODESEL | Input  | Mode selection signal, HS or LP mode                                                            |
| 0       | Output | A-ended data output signal, A differential output in HS mode, A single-ended output in LP mode. |
| ОВ      | Output | B-ended data output signal, B differential output in HS mode, B single-ended output in LP mode. |

#### **Primitive Instantiation**

## **Verilog Instantiation:**

UG289-1.7E 30(116)

```
MIPI_OBUF_A uut(
    .O(O),
    .OB(OB),
    .I(I),
    .IB(IB),
    .IL(IL),
    .MODESEL(MODESEL)
  );
VhdI Instantiation:
  COMPONENT MIPI_OBUF_A
      PORT (
         O:OUT std_logic;
         OB:OUT std_logic;
             I:IN std_logic;
             IB:IN std_logic;
         IL: IN std_logic;
         MODESEL: IN std_logic
      );
  END COMPONENT;
  uut: MIPI_OBUF_A
         PORT MAP (
           O = > O,
        OB=>OB,
            I=> I,
            IB=>IB,
        IL=>IL,
        MDOESEL=>MODESEL
        );
```

## 3.6.12 I3C IOBUF

#### **Primitive Introduction**

I3C Bi-Directional Buffer (I3C\_IOBUF) includes Normal mode and I3C mode.

I3C\_IOBUF is used as a bi-directional buffer when MODESEL is high and used as a normal buffer when MODESEL is low.

UG289-1.7E 31(116)

## **Devices Supported**

Table 3-17 I3C\_IOBUF Devices Supported

| Product Family | Series  | Device                                      |
|----------------|---------|---------------------------------------------|
|                | GW1N    | GW1N-9,GW1N-9C                              |
|                | GW1NR   | GW1NR-9,GW1NR-9C                            |
|                | GW1NS   | GW1NS-2, GW1NS-2C, GW1NS-4, GW1NS-4C        |
| LittleBee®     | GW1NSE  | GW1NSE-2C                                   |
|                | GW1NSER | GW1NSER-4C                                  |
| GW1NSR         |         | GW1NSR-2, GW1NSR-2C, GW1NSR-4,<br>GW1NSR-4C |

## **Port Diagram**

Figure 3-18 I3C\_IOBUF Port Diagram



## **Port Description**

Table 3-18 I3C\_IOBUF Port Description

| Ports   | I/O    | Description                                    |  |
|---------|--------|------------------------------------------------|--|
| 1       | Input  | Data Input Signal                              |  |
| Ю       | Inout  | Input and output signal, bidirectional         |  |
| MODESEL | Input  | Mode selection signal, Normal mode or I3C mode |  |
| 0       | Output | Data Output Signal                             |  |

## **Primitive Instantiation**

## **Verilog Instantiation:**

PORT (

```
I3C_IOBUF uut(
.O(O),
.IO(IO),
.I(I),
.MODESEL(MODESEL)
);
Vhdl Instantiation:
COMPONENT I3C_IOBUF
```

UG289-1.7E 32(116)

```
O:OUT std_logic;
IO:INOUT std_logic;
I:IN std_logic;
MODESEL:IN std_logic
);
END COMPONENT;
uut: I3C_IOBUF
PORT MAP (
O=>O,
IO=>IO,
I=>I,
MDOESEL=>MODESEL
);
```

# 3.6.13 MIPI\_IBUF\_HS/MIPI\_IBUF\_LP

#### **Primitive Introduction**

MIPI\_IBUF\_HS implements HS mode for differential input and MIPI\_IBUF\_LP implements LP mode via single-ended input.

## **Devices Supported**

Table 3-19 MIPI\_IBUF\_HS/MIPI\_IBUF\_LP Devices Supported

| Family                 | Series | Device  |
|------------------------|--------|---------|
| LittleBee <sup>®</sup> | GW1NR  | GW1NR-2 |

## **Functional Description**

You can use the combination of MIPI\_IBUF\_HS and MIPI\_IBUF\_LP to support HS and LP modes via Floorplanner. Input I of MIPI\_IBUF\_HS and I of MIPI\_IBUF\_LP should be connected to the same signal, and input IB of MIPI\_IBUF\_HS and IB of MIPI\_IBUF\_LP should be connected to the same signal.

#### **Port Diagram**

Figure 3-19 MIPI\_IBUF\_HS/MIPI\_IBUF\_LP Port Diagram



UG289-1.7E 33(116)

## **Port Description**

## Table 3-20 MIPI\_IBUF\_HS Port Description

| Port | I/O    | Description                                   |
|------|--------|-----------------------------------------------|
| 1    | Input  | In HS mode, differential input A-ended signal |
| IB   | Input  | In HS mode, differential input B-ended signal |
| ОН   | Output | In HS mode, data output signal                |

## Table 3-21 MIPI\_IBUF\_LP Port Description

| Port | I/O    | Description                             |
|------|--------|-----------------------------------------|
| 1    | Input  | In LP mode, A single-ended input signal |
| IB   | Input  | In LP mode, B single-ended input signal |
| OL   | Output | In LP mode, A-ended output singal       |
| ОВ   | Output | In LP mode, B-ended output singal       |

## **Connection Rule**

- The output OH of MIPI\_IBUF\_HS can be connected to lologic,
- The output OL and OB of MIPI\_IBUF\_LP are not allowed to be connected to lologic.

#### **Primitive Instantiation**

## **Verilog Instantiation:**

#### **VhdI Instantiation:**

```
COMPONENT MIPI_IBUF_HS
PORT (
OH:OUT std_logic;
```

UG289-1.7E 34(116)

```
I:IN std_logic;
      IB:IN std_logic
    );
END COMPONENT;
COMPONENT MIPI_IBUF_LP
    PORT (
      OL: OUT std_logic;
     OB:OUT std_logic;
          I:IN std_logic;
      IB:IN std_logic
    );
END COMPONENT;
hs: MIPI_IBUF_HS
       PORT MAP(
          OH=>OH,
          l=>I,
          IB=>IB
      );
lp: MIPI_IBUF_LP
       PORT MAP(
          OL=>OL,
          OB=>OB,
          l=>I,
          IB=>IB
      );
```

UG289-1.7E 35(116)

# 4 Input/Output Logic

I/O logic in GOWINSEMI FPGA products supports SDR and DDR modes, etc. In each mode, pin control (or pin differential signal pairs) can be configured as output signal, input signal, bi-directional signal and tristate output signal (output signal with tristate control).

#### Note!

- IOL6 and IOR6 pins of the devices of GW1N-1, GW1NR-1, GW1NZ-1, GW1NS-2, GW1NS-2C, GW1NSR-2C, GW1NSR-2 and GW1NSE-2C do not support IO logic.
- IOT2 and IOT3A pins of GW1N-2, GW1NZ-2 and GW1NR-2 devices do not support IO logic.
- IOL10 and IOR10 pins of the devices of GW1N-4, GW1N-4B, GW1NR-4, GW1NR-4B, GW1NRF-4B, GW1N-4C and GW1NR-4C do not support IO logic.

Figure 4-1 shows the output of the I/O logic in GOWINSEMI FPGA products.

**OTMUX TRIREG** TO **GND** Q1 **ODMUX OSER** Q0 **ODELMUX** ▶ ISI **OREG**  $\times$ PAD D [ DO IODELAY Logic View-Output

Figure 4-1 I/O Logic View-Output

Figure 4-2 shows the input of the I/O logic in GOWINSEMI FPGA products.

UG289-1.7E 36(116)

4 Input/Output Logic 4.1 SDR Mode

IDELMUX
INDD
INDD
IREG
IREGOUT
IDES
IDESOUT
IEM
LAG
LEAD
Logic View-Input

Figure 4-2 I/O Logic View-Input

# 4.1 SDR Mode

The input/output logic supports SDR mode and provides input register (IREG), output register (OREG) and tristate control register (TRIREG), the functions of which are the same as FF/LATCH in CFU. The FF/LATCH can be used as lologic when the input D of the FF/LATCH is driven by a Buffer/IODELAY that does not drive other lologics, or when the output Q of the FF/LATCH only drives a Buffer/IODELAY and the Buffer is not a MIPI Buffer.

# 4.2 DDR Mode Input Logic

## 4.2.1 IDDR

#### **Primitive Introduction**

Input Double Data Rate (IDDR)

#### **Functional Description**

Output data is provided to FPGA logic at the same clock edge in IDDR mode. IDDR logic diagram is as shown in Figure 4-3 and its timing diagram is as shown in Figure 4-4.

Figure 4-3 IDDR Logic Diagram



UG289-1.7E 37(116)

Figure 4-4 IDDR Timing Diagram



## **Port Diagram**

Figure 4-5 IDDR Port Diagram



## **Port Description**

**Table 4-1 IDDR Port Description** 

| Port Name | I/O    | Description             |
|-----------|--------|-------------------------|
| D         | Input  | IDDR data input signal  |
| CLK       | Input  | Clock input signal      |
| Q0,Q1     | Output | IDDR data output signal |

## **Parameters Description**

**Table 4-2 IDDR Parameter Description** 

| Name    | Value | Default | Description                |
|---------|-------|---------|----------------------------|
| Q0_INIT | 1'b0  | 1'b0    | Initial value of Q0 output |
| Q1_INIT | 1'b0  | 1'b0    | Initial value of Q1 output |

#### **Connection Rule**

Data input D of IDDR can be directly from IBUF or from the output DO of IODELAY module.

#### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to <u>5</u> IP Generation.

## **Verilog Instantiation:**

UG289-1.7E 38(116)

```
IDDR uut(
       .Q0(Q0),
       .Q1(Q1),
       .D(D),
       .CLK(CLK)
  );
  defparam uut.Q0_INIT=1'b0;
  defparam uut.Q1_INIT=1'b0;
VhdI Instantiation:
  COMPONENT IDDR
       GENERIC (Q0_INIT:bit:='0';
                     Q1_INIT:bit:='0'
         );
       PORT(
          Q0:OUT std_logic;
          Q1:OUT std_logic;
          D:IN std_logic;
          CLK:IN std_logic
        );
  END COMPONENT;
  uut:IDDR
      GENERIC MAP (Q0_INIT=>'0',
                         Q1 INIT=>'0'
        )
      PORT MAP (
            Q0 = > Q0,
            Q1 => Q1,
            D=>D,
            CLK=>CLK
      );
```

## **4.2.2 IDDRC**

#### **Primitive Introduction**

Dual Data Rate Input with Asynchronous Clear (IDDRC) is similar to IDDR to realize double data rate input and can be reset asynchronously.

UG289-1.7E 39(116)

## **Functional Description**

Output data is provided to FPGA logic at the same clock edge in IDDRC mode.

## Port Diagram

## Figure 4-6 IDDRC Port Diagram



## **Port Description**

**Table 4-3 IDDRC Port Description** 

| Port Name | I/O    | Description                                   |
|-----------|--------|-----------------------------------------------|
| D         | Input  | IDDRC data input signal                       |
| CLK       | Input  | Clock input signal                            |
| CLEAR     | Input  | Asynchronous reset input signal, active-high. |
| Q0,Q1     | Output | IDDRC data output signal                      |

## **Parameters Description**

**Table 4-4 IDDRC Parameter Description** 

| Name    | Value | Default | Description                    |
|---------|-------|---------|--------------------------------|
| Q0_INIT | 1'b0  | 1'b0    | The initial value of Q0 output |
| Q1_INIT | 1'b0  | 1'b0    | The initial value of Q1 output |

#### **Connection Rule**

Data input D of IDDRC can be directly from IBUF or from the output DO of IODELAY module.

## **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

## **Verilog Instantiation:**

```
IDDRC uut(
.Q0(Q0),
.Q1(Q1),
.D(D),
.CLK(CLK),
.CLEAR(CLEAR)
```

UG289-1.7E 40(116)

```
);
  defparam uut.Q0_INIT=1'b0;
  defparam uut.Q1 INIT = 1'b0;
VhdI Instantiation:
  COMPONENT IDDRC
       GENERIC (Q0_INIT:bit:='0';
                     Q1_INIT:bit:='0'
         );
       PORT(
          Q0:OUT std_logic;
          Q1:OUT std_logic;
          D:IN std_logic;
               CLEAR: IN std_logic;
          CLK:IN std_logic
      );
  END COMPONENT;
  uut:IDDRC
      GENERIC MAP (Q0_INIT=>'0',
                         Q1 INIT=>'0'
        )
      PORT MAP (
            Q0 = > Q0,
            Q1 => Q1,
            D=>D.
            CLEAR=>CLEAR.
            CLK=>CLK
       );
```

## 4.2.3 IDES4

#### **Primitive Introduction**

The 1 to 4 Deserializer (IDES4) is a deserializer of 1 bit serial input and 4 bits parallel output.

## **Functional Description**

IDES4 mode realizes 1:4 serial parallel conversion and output data is provided to FPGA logic at the same clock edge. CALIB is supported to adjust the sequence of output data. The data is shifted by one bit per pulse. After four shifts, the data output will be the same as the data before the

UG289-1.7E 41(116)

## shift. CALIB Timing diagram is as shown in Figure 4-7.

Figure 4-7 CALIB Timing Diagram



#### Note!

The pulse width and timing of the CALIB signal in the example are for reference only and can be adjusted as needed, the pulse width is equal to or greater than  $T_{PCLK}$ .

PCLK is usually obtained by FCLK frequency division:

$$f_{PCLK} = 1/2 f_{FCLK}$$

## **Port Diagram**

Figure 4-8 IDES4 Port Diagram



## **Port Description**

**Table 4-5 IDES4 Port Description** 

| Port Name | I/O    | Description                                                           |
|-----------|--------|-----------------------------------------------------------------------|
| D         | Input  | IDES4 data input signal                                               |
| FCLK      | Input  | High speed clock Input signal                                         |
| PCLK      | Input  | Primary clock input signal                                            |
| CALIB     | Input  | CALIB signal, used to adjust the sequence of output data, active-high |
| RESET     | Input  | Asynchronous reset input signal, active-high                          |
| Q3=Q0     | Output | IDES8 data output signal                                              |

UG289-1.7E 42(116)

## **Parameters Description**

**Table 4-6 IDES4 Parameter Description** 

| Name  | Value           | Default | Description         |
|-------|-----------------|---------|---------------------|
| GSREN | "false", "true" | "false" | Enable global reset |
| LSREN | "false", "true" | "true"  | Enable local reset  |

#### **Connection Rule**

Data input D of IDES4 can be directly from IBUF or from the output DO of IODELAY module.

#### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

## **Verilog Instantiation:**

```
IDES4 uut(
      .Q0(Q0),
      .Q1(Q1),
      .Q2(Q2),
      .Q3(Q3),
      .D(D),
      .FCLK(FCLK),
      .PCLK(PCLK),
      .CALIB(CALIB),
      .RESET(RESET)
  );
 defparam uut.GSREN="false";
 defparam uut.LSREN ="true";
VhdI Instantiation:
  COMPONENT IDES4
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true"
         );
       PORT(
          Q0:OUT std_logic;
          Q1:OUT std_logic;
          Q2:OUT std_logic;
               Q3:OUT std_logic;
```

UG289-1.7E 43(116)

```
D:IN std_logic;
             FCLK:IN std_logic;
             PCLK:IN std_logic;
             CALIB: IN std_logic;
       RESET:IN std_logic
   );
END COMPONENT;
uut:IDES4
   GENERIC MAP (GSREN=>"false",
                      LSREN=>"true"
     )
   PORT MAP (
          Q0 = > Q0
          Q1=>Q1.
          Q2=>Q2.
          Q3 = > Q3,
          D=>D,
          FCLK=>FCLK.
          PCLK=>PCLK.
          CALIB=>CALIB,
          RESET=>RESET
 );
```

## 4.2.4 IDES8

#### **Primitive Introduction**

The 1 to 8 Deserializer (IDES8) is a deserializer of 1 bit serial input and 8 bits parallel output.

## **Functional Description**

IDES8 mode realizes 1:8 serial parallel conversion and output data is provided to FPGA logic at the same clock edge. CALIB is supported to adjust the sequence of output data. The data is shifted by one bit per pulse. After four shifts, the data output will be the same as the data before the shift.

PCLK is usually obtained by FCLK frequency division:  $f_{PCLK} = 1/4 f_{FCLK}$ .

UG289-1.7E 44(116)

## **Port Diagram**

#### Figure 4-9 IDES8 Port Diagram



## **Port Description**

**Table 4-7 IDES8 Port Description** 

| Port Name | I/O    | Description                                                                  |
|-----------|--------|------------------------------------------------------------------------------|
| D         | Input  | IDES8 data input signal                                                      |
| FCLK      | Input  | High speed clock input signal                                                |
| PCLK      | Input  | Primary clock input signal                                                   |
| CALIB     | Input  | CALIB input signal, used to adjust the sequence of output data, active-high. |
| RESET     | Input  | Asynchronous reset input signal, active-high.                                |
| Q7=Q0     | Output | IDES8 data output signal                                                     |

## **Parameters Description**

**Table 4-8 IDES8 Parameter Description** 

| Name  | Value           | Default | Description         |
|-------|-----------------|---------|---------------------|
| GSREN | "false", "true" | "false" | Enable global reset |
| LSREN | "false", "true" | "true"  | Enable local reset  |

#### **Connection Rule**

Data input D of IDES8 can be directly from IBUF or from DO in IODELAY module.

#### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

## **Verilog Instantiation:**

.Q0(Q0), .Q1(Q1),

UG289-1.7E 45(116)

```
.Q2(Q2),
      .Q3(Q3),
      .Q4(Q4),
      .Q5(Q5),
      .Q6(Q6),
      .Q7(Q7),
      .D(D),
      .FCLK(FCLK),
      .PCLK(PCLK),
      .CALIB(CALIB),
      .RESET(RESET)
  );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
VhdI Instantiation:
  COMPONENT IDES8
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true"
         );
       PORT(
          Q0:OUT std_logic;
          Q1:OUT std_logic;
          Q2:OUT std_logic;
                Q3:OUT std_logic;
                Q4:OUT std_logic;
                Q5:OUT std_logic;
                Q6:OUT std_logic;
                Q7:OUT std_logic;
          D:IN std_logic;
               FCLK:IN std_logic;
                PCLK:IN std_logic;
                CALIB: IN std_logic;
          RESET:IN std_logic
      );
  END COMPONENT;
```

UG289-1.7E 46(116)

```
uut:IDES8
   GENERIC MAP (GSREN=>"false",
                     LSREN=>"true"
     )
   PORT MAP (
         Q0 = > Q0,
         Q1=>Q1,
         Q2=>Q2.
         Q3=>Q3.
         Q4 = > Q4.
         Q5=>Q5,
         Q6=>Q6.
         Q7=>Q7.
         D=>D.
         FCLK=>FCLK,
         PCLK=>PCLK,
         CALIB=>CALIB,
         RESET=>RESET
    );
```

## 4.2.5 IDES10

#### **Primitive Introduction**

The 1 to 10 Deserializer (IDES10) is a deserializer of 1 bit serial input and 10 bits parallel output.

#### **Functional Description**

IDES10 mode realizes 1:10 serial parallel conversion and output data is provided to FPGA logic at the same clock edge. CALIB is supported to adjust the sequence of output data. The data is shifted by one bit per pulse. After ten shifts, the data output will be the same as the data before the shift.

PCLK is usually obtained by FCLK frequency division:  $f_{\it PCLK} = 1/5\,f_{\it FCLK}$ 

UG289-1.7E 47(116)

## **Port Diagram**

Figure 4-10 IDES10 Port Diagram



## **Port Description**

**Table 4-9 IDES10 Port Description** 

| Port Name | I/O    | Description                                                            |
|-----------|--------|------------------------------------------------------------------------|
| D         | Input  | IDES10 data input signal                                               |
| FCLK      | Input  | High speed clock input signal                                          |
| PCLK      | Input  | Primary clock input signal                                             |
| CALIB     | Input  | CALIB signal, used to adjust the sequence of output data, active-high. |
| RESET     | Input  | Asynchronous reset input signal, active-high.                          |
| Q9=Q0     | Output | IDES10 data output signal                                              |

## **Parameters Description**

**Table 4-10 IDES10 Parameter Description** 

| Name  | Value           | Default | Description         |
|-------|-----------------|---------|---------------------|
| GSREN | "false", "true" | "false" | Enable global reset |
| LSREN | "false", "true" | "true"  | Enable local reset  |

#### **Connection Rule**

Data input D of IDES10 can be directly from IBUF or from DO in IODELAY module.

#### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

## **Verilog Instantiation:**

IDES10 uut( .Q0(Q0), .Q1(Q1),

UG289-1.7E 48(116)

```
.Q2(Q2),
      .Q3(Q3),
      .Q4(Q4),
      .Q5(Q5),
      .Q6(Q6),
      .Q7(Q7),
      .Q8(Q8),
      .Q9(Q9),
      .D(D),
      .FCLK(FCLK),
      .PCLK(PCLK),
      .CALIB(CALIB),
      .RESET(RESET)
 );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
VhdI Instantiation:
  COMPONENT IDES10
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true"
         );
       PORT(
          Q0:OUT std_logic;
          Q1:OUT std_logic;
          Q2:OUT std_logic;
                Q3:OUT std_logic;
                Q4:OUT std_logic;
                Q5:OUT std_logic;
                Q6:OUT std_logic;
                Q7:OUT std_logic;
                Q8:OUT std_logic;
                Q9:OUT std_logic;
          D:IN std_logic;
                FCLK:IN std_logic;
                PCLK:IN std_logic;
```

UG289-1.7E 49(116)

```
CALIB: IN std_logic;
       RESET:IN std_logic
   );
END COMPONENT;
uut:IDES10
   GENERIC MAP (GSREN=>"false",
                     LSREN=>"true"
     )
   PORT MAP (
         Q0 = > Q0,
         Q1 = > Q1
         Q2=>Q2.
         Q3=>Q3.
         Q4=>Q4.
         Q5=>Q5.
         Q6=>Q6.
         Q7=>Q7.
         Q8=>Q8.
         Q9=>Q9.
         D=>D,
         FCLK=>FCLK,
         PCLK=>PCLK,
         CALIB=>CALIB,
         RESET=>RESET
    );
```

#### **4.2.6 IVIDEO**

#### **Primitive Introduction**

The 1 to 7 Deserializer (IVIDEO) is a deserializer of 1 bit serial input and 7 bits parallel output.

#### **Functional Description**

IVIDEO mode realizes 1:7 serial parallel conversion and output data is provided to FPGA logic at the same clock edge. CALIB is supported to adjust the sequence of output data. The data is shifted by two bits per pulse. After seven shifts, the data output will be the same as the data before the shift.

PCLK is usually obtained by FCLK frequency division:

UG289-1.7E 50(116)

$$f_{PCLK} = 1/3.5 f_{FCLK}$$

## **Port Diagram**

Figure 4-11 IVIDEO Port Diagram



## **Port Description**

**Table 4-11 IVIDEO Port Description** 

| Port Name | I/O    | Description                                                            |
|-----------|--------|------------------------------------------------------------------------|
| D         | Input  | IVIDEO data input signal                                               |
| FCLK      | Input  | High speed clock input signal                                          |
| PCLK      | Input  | Primary clock input signal                                             |
| CALIB     | Input  | CALIB signal, used to adjust the sequence of output data, active-high. |
| RESET     | Input  | Asynchronous reset input signal, active-high.                          |
| Q6~Q0     | Output | IVIDEO data output signal                                              |

## **Parameters Description**

**Table 4-12 IVIDEO Parameter Description** 

| Name  | Value           | Default | Description         |
|-------|-----------------|---------|---------------------|
| GSREN | "false", "true" | "false" | Enable global reset |
| LSREN | "false", "true" | "true"  | Enable local reset  |

#### **Connection Rule**

Data input D of IVIDEO can be directly from IBUF or from DO in IODELAY module.

#### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

## **Verilog Instantiation:**

IVIDEO uut(

UG289-1.7E 51(116)

```
.Q0(Q0),
      .Q1(Q1),
      .Q2(Q2),
      .Q3(Q3),
      .Q4(Q4),
      .Q5(Q5),
      .Q6(Q6),
      .D(D),
      .FCLK(FCLK),
      .PCLK(PCLK),
      .CALIB(CALIB),
      .RESET(RESET)
  );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
Vhdl Instantiation:
  COMPONENT IVIDEO
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true"
         );
       PORT(
          Q0:OUT std_logic;
          Q1:OUT std_logic;
          Q2:OUT std_logic;
                Q3:OUT std_logic;
                Q4:OUT std_logic;
                Q5:OUT std_logic;
                Q6:OUT std_logic;
                 D:IN std_logic;
                FCLK:IN std_logic;
                PCLK:IN std_logic;
                CALIB: IN std_logic;
          RESET:IN std_logic
       );
  END COMPONENT;
```

UG289-1.7E 52(116)

```
uut:IVIDEO
   GENERIC MAP (GSREN=>"false",
                     LSREN=>"true"
     )
   PORT MAP (
         Q0 = > Q0,
         Q1 => Q1,
         Q2=>Q2,
         Q3=>Q3.
         Q4 = > Q4
         Q5 = > Q5,
         Q6=>Q6.
         D=>D.
         FCLK=>FCLK.
         PCLK=>PCLK.
         CALIB=>CALIB,
         RESET=>RESET
     );
```

## 4.2.7 IDES16

## **Primitive Introduction**

The 1 to 16 Deserializer (IDES16) is a deserializer of 1 bit serial input and 16 bits parallel output.

## **Devices Supported**

Table 4-13 IDES16 Devices Supported

| Product Family         | Series  | Device                                      |  |
|------------------------|---------|---------------------------------------------|--|
|                        | GW1N    | GW1N-1S, GW1N-9, GW1N-9C, GW1N-2            |  |
|                        | GW1NR   | GW1NR-9,GW1NR-9C, GW1NR-2                   |  |
|                        | GW1NS   | GW1NS-2, GW1NS-2C, GW1NS-4, GW1NS-4C        |  |
| LittleBee <sup>®</sup> | GW1NZ   | GW1NZ-2                                     |  |
|                        | GW1NSE  | GW1NSE-2C                                   |  |
|                        | GW1NSER | GW1NSER-4C                                  |  |
|                        | GW1NSR  | GW1NSR-2, GW1NSR-2C, GW1NSR-4,<br>GW1NSR-4C |  |

## **Functional Description**

IDES16 mode realizes 1:16 serial parallel conversion and output data is provided to FPGA logic at the same clock edge. CALIB is supported to

UG289-1.7E 53(116)

adjust the sequence of output data. Each pulse data is shifted by one bit. After sixteen shifts, the data output will be the same as the data before the shift.

PCLK is usually obtained by FCLK frequency division:  $f_{PCLK} = 1/8 f_{FCLK}$ .

#### **Port Diagram**

Figure 4-12 IDES16 Port Diagram



## **Port Description**

**Table 4-14 IDES16 Port Description** 

| Port Name | I/O    | Description                                                            |  |
|-----------|--------|------------------------------------------------------------------------|--|
| D         | Input  | IDES16 data input signal                                               |  |
| FCLK      | Input  | High speed clock input signal                                          |  |
| PCLK      | Input  | Primary clock input signal                                             |  |
| CALIB     | Input  | CALIB signal, used to adjust the sequence of output data, active-high. |  |
| RESET     | Input  | Asynchronous reset input signal, active-high.                          |  |
| Q15~Q0    | Output | IDES16 data output signal                                              |  |

## **Parameters Description**

**Table 4-15 IDES10 Parameter Description** 

| Name  | Value           | Default | Description         |
|-------|-----------------|---------|---------------------|
| GSREN | "false", "true" | "false" | Enable global reset |
| LSREN | "false", "true" | "true"  | Enable local reset  |

#### **Connection Rule**

Data input D of IDES16 can be directly from IBUF or from DO in

UG289-1.7E 54(116)

IODELAY module.

#### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

## **Verilog Instantiation:**

```
IDES16 uut(
      .Q0(Q0),
      .Q1(Q1),
      .Q2(Q2),
      .Q3(Q3),
      .Q4(Q4),
      .Q5(Q5),
      .Q6(Q6),
      .Q7(Q7),
      .Q8(Q8),
      .Q9(Q9),
      .Q10(Q10),
      .Q11(Q11),
      .Q12(Q12),
      .Q13(Q13),
      .Q14(Q14),
      .Q15(Q15),
      .D(D),
      .FCLK(FCLK),
      .PCLK(PCLK),
      .CALIB(CALIB),
      .RESET(RESET)
  );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
VhdI Instantiation:
  COMPONENT IDES16
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true"
         );
```

UG289-1.7E 55(116)

```
PORT(
        Q0:OUT std_logic;
        Q1:OUT std_logic;
        Q2:OUT std_logic;
             Q3:OUT std_logic;
             Q4:OUT std_logic;
             Q5:OUT std_logic;
             Q6:OUT std_logic;
             Q7:OUT std_logic;
             Q8:OUT std_logic;
             Q9:OUT std_logic;
             Q10:OUT std_logic;
             Q11:OUT std_logic;
             Q12:OUT std_logic;
             Q13:OUT std_logic;
             Q14:OUT std_logic;
             Q15:OUT std_logic;
        D:IN std_logic;
             FCLK:IN std_logic;
             PCLK:IN std_logic;
             CALIB: IN std_logic;
        RESET:IN std_logic
     );
END COMPONENT;
uut:IDES16
    GENERIC MAP (GSREN=>"false",
                       LSREN=>"true"
     )
    PORT MAP (
          Q0 = > Q0,
          Q1 => Q1,
          Q2=>Q2.
          Q3=>Q3,
          Q4 = > Q4.
          Q5=>Q5,
```

UG289-1.7E 56(116)

```
Q6=>Q6,
Q7=>Q7,
Q8=>Q8,
Q9=>Q9,
Q10=>Q10,
Q11=>Q11,
Q12=>Q12,
Q13=>Q13,
Q14=>Q14,
Q15=>Q15,
D=>D,
FCLK=>FCLK,
PCLK=>PCLK,
CALIB=>CALIB,
RESET=>RESET
```

## **4.2.8 IDDR MEM**

#### **Primitive Introduction**

);

The Input Double Data Rate with Memory (IDDR\_MEM) realizes double data rate input with memory.

## **Devices Supported**

Table 4-16 IDDR\_MEM Devices Supported

| Product Family | Series | Device                               |
|----------------|--------|--------------------------------------|
| Arora          | GW2A   | GW2A-18, GW2A-18C, GW2A-55, GW2A-55C |
|                | GW2AN  | GW2AN-55C                            |
|                | GW2AR  | GW2AR-18,GW2AR-18C                   |
|                | GW2ANR | GW2ANR-18C                           |

#### **Functional Description**

IDDR\_MEM output data is provided to FPGA logic at the same clock edge. IDDR\_MEM needs to be used with DQS. ICLK connects the DQSR90 of DQS output signals and sends data to IDDR\_MEM according to the ICLK clock edge. WADDR [2: 0] connects the WPOINT output signal of DQS; RADDR [2: 0] connects the RPOINT output signal of DQS.

The frequency relation between PCLK and ICLK is  $f_{\it PCLK} = f_{\it ICLK}$  . You can determine the phase relationship between PCLK and ICLK

UG289-1.7E 57(116)

according to the DLLSTEP value of DQS.

## Port Diagram

Figure 4-13 IDDR\_MEM Port Diagram



## **Port Description**

Table 4-17 IDDR\_MEM Port Description

| Port Name  | I/O    | Description                                    |  |
|------------|--------|------------------------------------------------|--|
| D          | Input  | IDDR_MEM data input signal                     |  |
| ICLK       | Input  | Clock input signal from DQSR90 in DQS module   |  |
| PCLK       | Input  | Primary clock input signal                     |  |
| WADDR[2:0] | Input  | Write address signal from WPOINT in DQS module |  |
| RADDR[2:0] | Input  | Read address signal from RPOINT in DQS module  |  |
| RESET      | Input  | Asynchronous reset input signal, active-high.  |  |
| Q1~Q0      | Output | IDDR_MEM data output signal                    |  |

## **Parameters Description**

Table 4-18 IDDR\_MEM Parameter Description

| Name  | Value           | Default | Description         |
|-------|-----------------|---------|---------------------|
| GSREN | "false", "true" | "false" | Enable global reset |
| LSREN | "false", "true" | "true"  | Enable local reset  |

#### **Connection Rule**

- Data input D of IDDR\_MEM can be directly from IBUF or from DO in IODELAY module.
- ICLK needs DQSR90 from a DQS module.
- WADDR[2:0] needs WPOINT from DQS module
- RADDR[2:0] needs RPOINT from DQS module;

#### **Primitive Instantiation**

#### **Verilog Instantiation:**

IDDR\_MEM iddr\_mem\_inst(

UG289-1.7E 58(116)

```
.Q0(q0),
       .Q1(q1),
       .D(d),
       .ICLK(iclk),
       .PCLK(pclk),
       .WADDR(waddr[2:0]),
       .RADDR(raddr[2:0]),
       .RESET(reset)
  );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
VhdI Instantiation:
  COMPONENT IDDR MEM
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true"
         );
       PORT(
          Q0:OUT std_logic;
                Q1:OUT std_logic;
          D:IN std_logic;
               ICLK:IN std_logic;
               PCLK:IN std_logic;
               WADDR:IN std_logic_vector(2 downto 0);
                RADDR:IN std_logic_vector(2 downto 0);
          RESET:IN std_logic
      );
  END COMPONENT;
  uut:IDDR MEM
      GENERIC MAP (GSREN=>"false",
                         LSREN=>"true"
        )
      PORT MAP (
            Q0 = > q0,
            Q1 = > q1,
            D=>d
```

UG289-1.7E 59(116)

```
ICLK=>iclk,
PCLK=>pclk,
WADDR=>waddr,
RADDR=>raddr,
RESET=>reset
);
```

## **4.2.9 IDES4 MEM**

#### **Primitive Introduction**

4 to 1 Deserializer with Memory (IDES4\_MEM) realizes 1:4 serial-parallel conversion with memory.

## **Devices Supported**

Table 4-19 IDES4\_MEM Devices Supported

| Product Family | Series | Device                               |
|----------------|--------|--------------------------------------|
| Arora          | GW2A   | GW2A-18, GW2A-18C, GW2A-55, GW2A-55C |
|                | GW2AN  | GW2AN-55C                            |
|                | GW2AR  | GW2AR-18,GW2AR-18C                   |
|                | GW2ANR | GW2ANR-18C                           |

## **Functional Description**

IDES4\_MEM realizes 1:4 serial parallel conversion and the output data is provided to FPGA logic at the same clock edge. CALIB is supported to adjust the sequence of output data. Each pulse data is shifted by one bit. After four shifts, the data output will be the same as the data before the shift.

The ICLK connects the output signal DQSR90 of DQS and sends data to IDES4\_MEM according to the ICLK clock edge. WADDR [2: 0] connects the output signal WPOINT of DQS; RADDR [2: 0] connects the output signal RPOINT of DQS.

The frequency relation between PCLK, FCLK and ICLK is  $f_{PCLK}$  = 1/2  $f_{FCLK}$  = 1/2  $f_{ICLK}$ 

You can determine the phase relationship between PCLK and ICLK according to the DLLSTEP value of DQS.

UG289-1.7E 60(116)

## **Port Diagram**

Figure 4-14 IDES4\_MEM Port Diagram



## **Port Description**

Table 4-20 IDES4\_MEM Port Description

| Port Name  | I/O    | Description                                                            |  |
|------------|--------|------------------------------------------------------------------------|--|
| D          | Input  | IDES4_MEM data input signal                                            |  |
| ICLK       | Input  | Clock input signal from DQSR90 in DQS module                           |  |
| FCLK       | Input  | High speed clock input signal                                          |  |
| PCLK       | Input  | Primary clock input signal                                             |  |
| WADDR[2:0] | Input  | Write address signal from WPOINT in DQS module                         |  |
| RADDR[2:0] | Input  | Read address signal from RPOINT in DQS module                          |  |
| CALIB      | Input  | CALIB signal, used to adjust the sequence of output data, active-high. |  |
| RESET      | Input  | Asynchronous reset input signal, active-high.                          |  |
| Q3~Q0      | Output | IDES4_MEM data output signal                                           |  |

## **Parameters Description**

Table 4-21 IDES4\_MEM Parameter Description

| Name  | Value           | Default | Description         |
|-------|-----------------|---------|---------------------|
| GSREN | "false", "true" | "false" | Enable global reset |
| LSREN | "false", "true" | "true"  | Enable local reset  |

#### **Connection Rule**

- Data input D of IDES4\_MEM can be directly from IBUF or from DO in IODELAY module.
- ICLK needs DQSR90 from a DQS module.

UG289-1.7E 61(116)

- WADDR[2:0] needs WPOINT from DQS module
- RADDR[2:0] needs RPOINT from DQS module;

#### **Primitive Instantiation**

```
Verilog Instantiation:
```

```
IDES4_MEM ides4_mem_inst(
       .Q0(q0),
       .Q1(q1),
       .Q2(q2),
       .Q3(q3),
       .D(d),
       .ICLK(iclk),
       .FCLK(fclk),
       .PCLK (pclk),
       .WADDR(waddr[2:0]),
       .RADDR(raddr[2:0]),
       .CALIB(calib),
       .RESET(reset)
  );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
Vhdl Instantiation:
  COMPONENT IDES4_MEM
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true"
         );
       PORT(
          Q0:OUT std_logic;
                Q1:OUT std_logic;
                Q2:OUT std_logic;
                Q3:OUT std_logic;
          D:IN std_logic;
                ICLK:IN std_logic;
                FCLK:IN std_logic;
                PCLK:IN std_logic;
                WADDR:IN std_logic_vector(2 downto 0);
```

UG289-1.7E 62(116)

```
RADDR:IN std_logic_vector(2 downto 0);
             CALIB: IN std_logic;
        RESET:IN std_logic
    );
END COMPONENT;
uut:IDES4_MEM
    GENERIC MAP (GSREN=>"false",
                      LSREN=>"true"
     )
    PORT MAP (
          Q0 = > q0,
          Q1 = > q1,
          Q2 = > q2,
          Q3 = > q3,
          D=>d
          ICLK=>iclk,
          FCLK=>fclk,
          PCLK=>pclk,
          WADDR=>waddr,
          RADDR=>raddr,
          CALIB=>calib,
          RESET=>reset
   );
```

# 4.2.10 IDES8 MEM

#### **Primitive Introduction**

8 to 1 Deserializer with Memory (IDES8\_MEM) realizes 1:8 serial parallel conversion with memory.

### **Devices Supported**

Table 4-22 IDES8\_MEM Devices Supported

| Product Family | Series | Device                               |
|----------------|--------|--------------------------------------|
| Arora          | GW2A   | GW2A-18, GW2A-18C, GW2A-55, GW2A-55C |
|                | GW2AN  | GW2AN-55C                            |
|                | GW2AR  | GW2AR-18,GW2AR-18C                   |
|                | GW2ANR | GW2ANR-18C                           |

UG289-1.7E 63(116)

### **Functional Description**

IDES8\_MEM realizes 1:8 serial parallel conversion and output data is provided to FPGA logic at the same clock edge. CALIB is supported to adjust the sequence of output data. The data is shifted by one bit per pulse. After eight shifts, the data output will be the same as the data before the shift. The ICLK connects the output signal DQSR90 of DQS and sends data to IDES8\_MEM according to the ICLK clock edge. WADDR[2:0] connects the output signal WPOINT of DQS; RADDR[2:0] connects output signal RPOINT of DQS.

4.2 DDR Mode Input Logic

The frequency relation between PCLK, FCLK and ICLK is  $f_{PCLK}$  = 1/4  $f_{FCLK}$  = 1/4  $f_{ICLK}$ 

You can determine the phase relationship between PCLK and ICLK according to the DLLSTEP value of DQS.

### **Port Diagram**

Figure 4-15 IDES8\_MEM Port Diagram



### **Port Description**

Table 4-23 IDES8\_MEM Port Description

| Port Name  | I/O   | Description                                                            |
|------------|-------|------------------------------------------------------------------------|
| D          | Input | IDES8_MEM data input signal                                            |
| ICLK       | Input | Clock input signal from DQSR90 in DQS module                           |
| FCLK       | Input | High speed clock Input signal                                          |
| PCLK       | Input | Primary clock input signal                                             |
| WADDR[2:0] | Input | Write address signal from WPOINT in DQS module                         |
| RADDR[2:0] | Input | Read address signal from RPOINT in DQS module                          |
| CALIB      | Input | CALIB signal, used to adjust the sequence of output data, active-high. |
| RESET      | Input | Asynchronous reset input signal, active-high.                          |

UG289-1.7E 64(116)

| Port Name | I/O    | Description                  |
|-----------|--------|------------------------------|
| Q7~Q0     | Output | IDES8_MEM data output signal |

### **Parameters Description**

#### Table 4-24 IDES8\_MEM Parameters Description

| Name  | Value           | Default | Description         |
|-------|-----------------|---------|---------------------|
| GSREN | "false", "true" | "false" | Enable global reset |
| LSREN | "false", "true" | "true"  | Enable local reset  |

#### **Connection Rule**

- Data input D of IDES8\_MEM can be directly from IBUF or from DO in IODELAY module.
- ICLK needs DQSR90 from a DQS module.
- WADDR[2:0] needs WPOINT from DQS module
- RADDR[2:0] needs RPOINT from DQS module.

### **Primitive Instantiation**

### **Verilog Instantiation:**

```
IDES8_MEM ides8_mem_inst(
    .Q0(q0),
    .Q1(q1),
    .Q2(q2),
    .Q3(q3),
    .Q4(q4),
    .Q5(q5),
    .Q6(q6),
    .Q7(q7),
    .D(d),
    .ICLK(iclk),
    .FCLK(fclk),
    .PCLK (pclk),
    .WADDR(waddr[2:0]),
    .RADDR(raddr[2:0]),
    .CALIB(calib),
    .RESET(reset)
);
```

UG289-1.7E 65(116)

```
defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
VhdI Instantiation:
  COMPONENT IDES8 MEM
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true"
         );
       PORT(
          Q0:OUT std_logic;
                Q1:OUT std_logic;
                Q2:OUT std_logic;
                Q3:OUT std_logic;
                Q4:OUT std_logic;
                Q5:OUT std_logic;
                Q6:OUT std_logic;
                Q7:OUT std_logic;
          D:IN std_logic;
                ICLK:IN std_logic;
                FCLK:IN std_logic;
                PCLK:IN std_logic;
                WADDR:IN std_logic_vector(2 downto 0);
                RADDR:IN std_logic_vector(2 downto 0);
                CALIB: IN std_logic;
          RESET:IN std_logic
      );
  END COMPONENT;
  uut:IDES8_MEM
      GENERIC MAP (GSREN=>"false",
                         LSREN=>"true"
        )
      PORT MAP (
             Q0 = > q0,
             Q1 = > q1,
             Q2 = > q2
             Q3 = > q3,
```

UG289-1.7E 66(116)

Q4=>q4, Q5=>q5, Q6=>q6, Q7=>q7, D=>d, ICLK=>iclk, FCLK=>fclk, PCLK=>pclk, WADDR=>waddr, RADDR=>raddr, CALIB=>calib, RESET=>reset

# 4.3 DDR Mode Output Logic

### 4.3.1 ODDR

### **Primitive Introduction**

);

Dual Data Rate Output (ODDR)

## **Functional Description**

ODDR mode is used for transferring double data rate signals from FPGA devices. Where Q0 is the double rate data output, Q1 is used for the OEN signal of IOBUF/TBUF connected by Q1. ODDR logic diagram is as shown in Figure 4-16 and its timing diagram is as shown in Figure 4-17.

Figure 4-16 ODDR Logic Diagram



UG289-1.7E 67(116)

Figure 4-17 ODDR Timing Diagram



### **Port Diagram**

Figure 4-18 ODDR Port Diagram



# **Port Description**

**Table 4-25 ODDR Port Description** 

| Port Name | I/O    | Description                                                                                                               |
|-----------|--------|---------------------------------------------------------------------------------------------------------------------------|
| D0,D1     | Input  | ODDR data input signal                                                                                                    |
| TX        | Input  | Q1 generated by TRI-DDRX1                                                                                                 |
| CLK       | Input  | Clock input signal                                                                                                        |
| Q0        | Output | ODDR data output signal                                                                                                   |
| Q1        | Output | ODDR tristate enable control data output can be connected to the IOBUF/TBUF OEN signal connected to Q0, or left floating. |

# **Parameter Description**

**Table 4-26 ODDR Parameter Description** 

| Name      | Value      | Default | Description                      |
|-----------|------------|---------|----------------------------------|
| TXCLK_POL | 1'b0, 1'b1 | 1'b0    | Q1 output clock polarity control |

UG289-1.7E 68(116)

| Name | Value | Default | Description                                       |
|------|-------|---------|---------------------------------------------------|
|      |       |         | 1'b0:Q1 posedge output;<br>1'b1:Q1 negedge output |
| INIT | 1'b0  | 1'b0    | Initial value of ODDR output                      |

#### **Connection Rule**

- Q0 can be directly connected to OBUF, or connected to input port DI through IODELAY module;
- Q1 shall be connected to the OEN signal of IOBUF/TBUF connected to Q0, or left floating.

#### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

### **Verilog Instantiation:**

```
ODDR uut(
     .Q0(Q0),
     .Q1(Q1),
     .D0(D0),
     .D1(D1),
    .TX(TX),
     .CLK(CLK)
  );
  defparam uut.INIT=1'b0;
  defparam uut.TXCLK POL=1'b0;
VhdI Instantiation:
  COMPONENT ODDR
       GENERIC (CONSTANT INIT: std_logic:='0';
                     TXCLK_POL:bit:='0'
         );
       PORT(
          Q0:OUT std_logic;
          Q1:OUT std_logic;
          D0:IN std_logic;
                D1:IN std_logic;
                TX:IN std_logic;
          CLK:IN std_logic
```

UG289-1.7E 69(116)

### **4.3.2 ODDRC**

#### **Primitive Introduction**

Dual Data Rate Output with Asynchronous Clear (ODDRC) is similar to ODDR to realize double data rate and can be reset asynchronously.

### **Functional Description**

ODDRC mode is used for transferring double data rate signals from FPGA devices. Where Q0 is the double rate data output, Q1 is used for the OEN signal of IOBUF/TBUF connected to Q1. Its logic diagram is as shown in Figure 4-19.

Figure 4-19 ODDRC Logic Diagram



UG289-1.7E 70(116)

### **Port Diagram**

Figure 4-20 ODDRC Port Diagram



### **Port Description**

**Table 4-27 ODDRC Port Description** 

| Port Name | I/O    | Description                                                                                                                     |  |
|-----------|--------|---------------------------------------------------------------------------------------------------------------------------------|--|
| D0, D1    | Input  | ODDRC data Input Signal                                                                                                         |  |
| TX        | Input  | Input Q1 generated by TRI-DDRX1                                                                                                 |  |
| CLK       | Input  | Clock input signal                                                                                                              |  |
| CLEAR     | Input  | Asynchronous reset input signal, active-high.                                                                                   |  |
| Q0        | Output | ODDRC data output signal                                                                                                        |  |
| Q1        | Output | ODDR tristate enable control data output can<br>be connected to the IOBUF/TBUF OEN signal<br>connected to Q0, or left floating. |  |

### **Parameter Description**

**Table 4-28 ODDRC Parameter Description** 

| Name      | Value      | Default | Description                                                                     |
|-----------|------------|---------|---------------------------------------------------------------------------------|
| TXCLK_POL | 1'b0, 1'b1 | 1'b0    | Q1 output clock polarity control 1'b0:Q1 posedge output; 1'b1:Q1 negedge output |
| INIT      | 1'b0       | 1'b0    | Initial value of ODDRC output                                                   |

#### **Connection Rule**

- Q0 can directly connect OBUF, or connect input port DI in IODELAY module:
- Q1 shall connect the OEN signal of IOBUF/TBUF connected by Q0, or left floating.

#### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

### **Verilog Instantiation:**

ODDRC uut(

UG289-1.7E 71(116)

```
.Q0(Q0),
    .Q1(Q1),
    .D0(D0),
    .D1(D1),
    .TX(TX),
    .CLK(CLK),
    .CLEAR(CLEAR)
  );
  defparam uut.INIT=1'b0;
  defparam uut.TXCLK_POL=1'b0;
Vhdl Instantiation:
  COMPONENT ODDRC
       GENERIC (CONSTANT INIT : std_logic :='0';
                    TXCLK POL:bit:='0'
         );
       PORT(
          Q0:OUT std_logic;
          Q1:OUT std_logic;
          D0:IN std_logic;
               D1:IN std_logic;
               TX:IN std_logic;
               CLK:IN std_logic;
          CLEAR:IN std_logic
      );
  END COMPONENT;
  uut:ODDRC
      GENERIC MAP (INIT=>'0',
                        TXCLK POL=>'0'
        )
      PORT MAP (
            Q0 = > Q0,
            Q1 => Q1,
            D0=>D0,
            D1=>D1,
            TX = > TX,
```

UG289-1.7E 72(116)

### 4.3.3 OSER4

#### **Primitive Introduction**

The 4 to 1 Serializer (OSER4) is a serializer of 4 bits parallel input and 1 bit serial output.

### **Functional Description**

OSER4 mode realizes 4:1 parallel to serial conversion, and Q0 is the serial output, Q1 is used for the OEN signal of IOBUF/TBUF connected to Q0. Its logic diagram is as shown in Figure 4-21.

Figure 4-21 OSER4 Logic Diagram



PCLK is usually obtained by FCLK frequency division:  $f_{PCLK} = 1/2 f_{FCLK}$ .

### **Port Diagram**

Figure 4-22 OSER4 Port Diagram



UG289-1.7E 73(116)

### **Port Description**

#### **Table 4-29 OSER4 Port Description**

| Port Name | I/O    | Description                                                                                                                |  |
|-----------|--------|----------------------------------------------------------------------------------------------------------------------------|--|
| D3~D0     | Input  | OSER4 data input signal                                                                                                    |  |
| TX1~TX0   | Input  | Q1 generated by TRI-DDRX2                                                                                                  |  |
| FCLK      | Input  | High speed clock input signal                                                                                              |  |
| PCLK      | Input  | Primary clock input signal                                                                                                 |  |
| RESET     | Input  | Asynchronous reset input signal, active-high.                                                                              |  |
| Q0        | Output | OSER4 data output signal                                                                                                   |  |
| Q1        | Output | OSER4 tristate enable control data output can be connected to the IOBUF/TBUF OEN signal connected to Q0, or left floating. |  |

### **Parameter Description**

Table 4-30 IDES8\_MEM Parameter Description

| Name      | Value           | Default | Description                                                                                                                               |
|-----------|-----------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------|
| GSREN     | "false", "true" | "false" | Enable global reset                                                                                                                       |
| LSREN     | "false", "true" | "true"  | Enable local reset                                                                                                                        |
| TXCLK_POL | 1'b0, 1'b1      | 1'b0    | Q1 output clock polarity control 1'b0: data posedge output 1'b1: data negedge output                                                      |
| HWL       | "false", "true" | "false" | OSER4 data d_up0/1 timing relationship control "False ": d_up1 is one cycle ahead of d_up0; "True ": d_up1 and d_up0 have the same timing |

### **Connection Rule**

- Q0 can directly connect OBUF, or connect input port DI in IODELAY module;
- Q1 shall connect the OEN signal of IOBUF/TBUF connected to Q0, or left floating.

#### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

### **Verilog Instantiation:**

OSER4 uut( .Q0(Q0), .Q1(Q1),

UG289-1.7E 74(116)

```
.D0(D0),
      .D1(D1),
      .D2(D2),
      .D3(D3),
      .TX0(TX0),
      .TX1(TX1),
      .PCLK(PCLK),
      .FCLK(FCLK),
      .RESET(RESET)
  );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
  defparam uut.HWL ="false";
  defparam uut.TXCLK_POL =1'b0;
VhdI Instantiation:
  COMPONENT OSER4
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true";
                     HWL:string:="false";
                     TXCLK_POL:bit:='0'
         );
       PORT(
          Q0:OUT std_logic;
          Q1:OUT std_logic;
          D0:IN std_logic;
                D1:IN std_logic;
                D2:IN std_logic;
                D3:IN std_logic;
                TX0:IN std_logic;
                TX1:IN std_logic;
                FCLK:IN std_logic;
                PCLK:IN std_logic;
          RESET:IN std_logic
      );
  END COMPONENT;
```

UG289-1.7E 75(116)

```
uut:OSER4
   GENERIC MAP (GSREN=>"false",
                     LSREN=>"true",
                     HWL=>"false",
                     TXCLK_POL=>'0'
     )
   PORT MAP (
         Q0 = > Q0,
         Q1 => Q1,
         D0=>D0,
         D1=>D1,
         D2=>D2.
         D3=>D3.
         TX0=>TX0.
         TX1=>TX1,
         FCLK=>FCLK,
         PCLK=>PCLK,
         RESET=>RESET
    );
```

### **4.3.4 OSER8**

### **Primitive Introduction**

The 8 to 1 Serializer (OSER8) is a serializer of 8 bits parallel input and 1 bit serial output.

### **Functional Description**

OSER8 mode realizes 8:1 parallel to serial conversion. Where Q0 is the serial output, Q1 is used for the OEN signal of IOBUF/TBUF connected to Q0. Its logic diagram is as shown in Figure 4-23.

UG289-1.7E 76(116)

Figure 4-23 OSER8 Logic Diagram



PCLK is usually obtained by FCLK frequency division:  $f_{PCLK} = 1/4 f_{FCLK}$ .

# **Port Diagram**

Figure 4-24 OSER8 Port Diagram



# **Port Description**

**Table 4-31 OSER4 Port Description** 

| Port Name | I/O    | Description                                                                                                                |
|-----------|--------|----------------------------------------------------------------------------------------------------------------------------|
| D7~D0     | Input  | OSER8 data input signal                                                                                                    |
| TX3~TX0   | Input  | Q1 generated by TRI-DDRX4                                                                                                  |
| FCLK      | Input  | High speed clock input signal                                                                                              |
| PCLK      | Input  | Primary clock input signal                                                                                                 |
| RESET     | Input  | Asynchronous reset input signal, active-high.                                                                              |
| Q0        | Output | OSER8 data output signal                                                                                                   |
| Q1        | Output | OSER8 tristate enable control data output can be connected to the IOBUF/TBUF OEN signal connected to Q0, or left floating. |

UG289-1.7E 77(116)

### **Parameter Description**

Table 4-32 IDES8\_MEM Parameter Description

| Name      | Value           | Default | Description                                                                                                                                     |
|-----------|-----------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| GSREN     | "false", "true" | "false" | Enable global reset                                                                                                                             |
| LSREN     | "false", "true" | "true"  | Enable local reset                                                                                                                              |
| TXCLK_POL | 1'b0, 1'b1      | 1'b0    | <ul> <li>Q1 output clock polarity control</li> <li>1'b0: data posedge output</li> <li>1'b1: data negedge output</li> </ul>                      |
| HWL       | "false", "true" | "false" | OSER8 data d_up0/1 timing relationship control  • "false ": d_up1 is one cycle ahead of d_up0;  • "true ": d_up1 and d_up0 have the same timing |

#### **Connection Rule**

- Q0 can directly connect OBUF, or connect input port DI in IODELAY module:
- Q1 shall connect the OEN signal of IOBUF/TBUF connected to Q0, or left floating.

#### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

### **Verilog Instantiation:**

OSER8 uut(

.Q0(Q0),

.Q1(Q1),

.D0(D0),

.D1(D1),

.D2(D2),

.D3(D3),

.D4(D4),

.D5(D5),

.D6(D6),

.D7(D7),

.TX0(TX0),

.TX1(TX1),

.TX2(TX2),

.TX3(TX3),

UG289-1.7E 78(116)

```
.PCLK(PCLK),
      .FCLK(FCLK),
      .RESET(RESET)
  );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
  defparam uut.HWL ="false";
  defparam uut.TXCLK_POL =1'b0;
VhdI Instantiation:
  COMPONENT OSER8
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true";
                     HWL:string:="false";
                     TXCLK_POL:bit:='0'
         );
       PORT(
          Q0:OUT std_logic;
          Q1:OUT std_logic;
          D0:IN std_logic;
                D1:IN std_logic;
                D2:IN std_logic;
                D3:IN std_logic;
                D4:IN std_logic;
                D5:IN std_logic;
                D6:IN std_logic;
                D7:IN std_logic;
                TX0:IN std_logic;
                TX1:IN std_logic;
                TX2:IN std_logic;
                TX3:IN std_logic;
                FCLK:IN std_logic;
                PCLK:IN std_logic;
          RESET:IN std_logic
      );
  END COMPONENT;
```

UG289-1.7E 79(116)

```
uut:OSER8
   GENERIC MAP (GSREN=>"false",
                     LSREN=>"true",
                     HWL=>"false",
                     TXCLK_POL=>'0'
     )
   PORT MAP (
         Q0 = > Q0,
         Q1 = > Q1,
         D0=>D0,
         D1=>D1,
         D2=>D2.
         D3=>D3.
         D4=>D4.
         D5=>D5.
         D6=>D6,
         D7=>D7.
         TX0=>TX0,
         TX1=>TX1,
         TX2=>TX2,
         TX3=>TX3,
         FCLK=>FCLK,
         PCLK=>PCLK,
         RESET=>RESET
    );
```

### 4.3.5 OSER10

#### **Primitive Introduction**

The 10 to 1 Serializer (OSER10) is a serializer of 10 bits parallel input and 1 bit serial output.

# **Functional Description**

OSER10 mode realizes 10:1 parallel to serial conversion. PCLK is usually obtained by FCLK frequency division,  $f_{PCLK}=1/5\,f_{FCLK}$ .

UG289-1.7E 80(116)

### **Port Diagram**

Figure 4-25 OSER10 Port Diagram



### **Port Description**

**Table 4-33 OSER10 Port Description** 

| Port Name | I/O    | Description                                   |
|-----------|--------|-----------------------------------------------|
| D9~D0     | Input  | OSER10 data input signal                      |
| FCLK      | Input  | High speed clock input signal                 |
| PCLK      | Input  | Primary clock input signal                    |
| RESET     | Input  | Asynchronous reset input signal, active-high. |
| Q         | Output | OSER10 data output signal                     |

### **Parameter Description**

**Table 4-34 OSER10 Parameter Description** 

| Name  | Value           | Default | Description         |
|-------|-----------------|---------|---------------------|
| GSREN | "false", "true" | "false" | Enable global reset |
| LSREN | "false", "true" | "true"  | Enable local reset  |

### **Connection Rule**

Q can directly connect to OBUF, or connect to input port DI in IODELAY module.

#### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

### **Verilog Instantiation:**

OSER10 uut( .Q(Q), .D0(D0),

UG289-1.7E 81(116)

```
.D1(D1),
       .D2(D2),
       .D3(D3),
      .D4(D4),
      .D5(D5),
      .D6(D6),
       .D7(D7),
       .D8(D8),
       .D9(D9),
       .PCLK(PCLK),
      .FCLK(FCLK),
      .RESET(RESET)
  );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
Vhdl Instantiation:
  COMPONENT OSER10
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true"
         );
       PORT(
          Q:OUT std_logic;
           D0:IN std_logic;
                D1:IN std_logic;
                D2:IN std_logic;
                D3:IN std_logic;
                D4:IN std_logic;
                D5:IN std_logic;
                D6:IN std_logic;
                D7:IN std_logic;
                D8:IN std_logic;
                D9:IN std_logic;
                FCLK:IN std_logic;
                PCLK:IN std_logic;
           RESET:IN std_logic
```

UG289-1.7E 82(116)

```
);
END COMPONENT;
uut:OSER10
   GENERIC MAP (GSREN=>"false",
                    LSREN=>"true"
     )
   PORT MAP (
         Q=>Q.
         D0=>D0,
         D1=>D1,
         D2=>D2,
         D3=>D3.
         D4=>D4,
         D5=>D5.
         D6=>D6.
         D7=>D7.
         D8=>D8.
         D9=>D9,
         FCLK=>FCLK,
         PCLK=>PCLK.
         RESET=>RESET
    );
```

### **4.3.6 OVIDEO**

### **Primitive Introduction**

The 7 to 1 Serializer (OVIDEO) is a serializer of 7 bits parallel input and 1 bit serial output,

### **Functional Description**

OVIDEO mode realizes 7:1 parallel to serial conversion. PCLK is usually obtained by FCLK frequency division:  $f_{PCLK} = 1/3.5 \, f_{FCLK}$ .

UG289-1.7E 83(116)

### **Port Diagram**

Figure 4-26 OVIDEO Port Diagram



### **Port Description**

**Table 4-35 OVIDEO Port Description** 

| Port Name | I/O    | Description                                   |
|-----------|--------|-----------------------------------------------|
| D6~D0     | Input  | OVIDEO data input signal                      |
| FCLK      | Input  | High speed clock input signal                 |
| PCLK      | Input  | Primary clock input signal                    |
| RESET     | Input  | Asynchronous reset input signal, active-high. |
| Q         | Output | OVIDEO data output signal                     |

### **Parameter Description**

**Table 4-36 OVIDEO Parameter Description** 

| Name  | Value           | Default | Description         |
|-------|-----------------|---------|---------------------|
| GSREN | "false", "true" | "false" | Enable global reset |
| LSREN | "false", "true" | "true"  | Enable local reset  |

#### **Connection Rule**

Q can directly connect to OBUF, or connect to input port DI in IODELAY module;

### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

### **Verilog Instantiation:**

OVIDEO uut(
.Q(Q),
.D0(D0),
.D1(D1),

UG289-1.7E 84(116)

```
.D2(D2),
      .D3(D3),
      .D4(D4),
      .D5(D5),
      .D6(D6),
      .PCLK(PCLK),
      .FCLK(FCLK),
      .RESET(RESET)
  );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
VhdI Instantiation:
  COMPONENT OVIDEO
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true"
         );
       PORT(
          Q:OUT std_logic;
          D0:IN std_logic;
                D1:IN std_logic;
               D2:IN std_logic;
               D3:IN std_logic;
               D4:IN std_logic;
               D5:IN std_logic;
               D6:IN std_logic;
               FCLK:IN std_logic;
                PCLK:IN std_logic;
          RESET:IN std_logic
      );
  END COMPONENT;
  uut:OVIDEO
      GENERIC MAP (GSREN=>"false",
                         LSREN=>"true"
        )
      PORT MAP (
```

UG289-1.7E 85(116)

```
Q=>Q,
D0=>D0,
D1=>D1,
D2=>D2,
D3=>D3,
D4=>D4,
D5=>D5,
D6=>D6,
FCLK=>FCLK,
PCLK=>PCLK,
RESET=>RESET
```

### 4.3.7 OSER16

#### **Primitive Introduction**

);

The 16 to 1 Serializer (OSER16) is a serializer of 16 bits parallel input and 1 bit serial output.

# **Devices Supported**

Table 4-37 OSER16 Devices Supported

| Product Family         | Series  | Device                                      |
|------------------------|---------|---------------------------------------------|
|                        | GW1N    | GW1N-1S, GW1N-9, GW1N-9C, GW1N-2            |
|                        | GW1NR   | GW1NR-9,GW1NR-9C, GW1NR-2                   |
| LittleBee <sup>®</sup> | GW1NS   | GW1NS-2, GW1NS-2C, GW1NS-4, GW1NS-4C        |
|                        | GW1NZ   | GW1NZ-2                                     |
|                        | GW1NSE  | GW1NSE-2C                                   |
|                        | GW1NSER | GW1NSER-4C                                  |
|                        | GW1NSR  | GW1NSR-2, GW1NSR-2C, GW1NSR-4,<br>GW1NSR-4C |

### **Functional Description**

OSER16 mode realizes 16:1 parallel to serial conversion. PCLK is usually obtained by FCLK frequency division:  $f_{PCLK} = 1/8 f_{FCLK}$ .

UG289-1.7E 86(116)

### **Port Diagram**

Figure 4-27 OSER16 Port Diagram



### **Port Description**

**Table 4-38 OSER16 Port Description** 

| Port Name | I/O    | Description                                   |
|-----------|--------|-----------------------------------------------|
| D15~D0    | Input  | OSER16 data input signal                      |
| FCLK      | Input  | High speed clock input signal                 |
| PCLK      | Input  | Primary clock input signal                    |
| RESET     | Input  | Asynchronous reset input signal, active-high. |
| Q         | Output | IDES8_MEM data output signal                  |

### **Parameter Description**

**Table 4-39 OSER16 Parameter Description** 

| Name  | Value           | Default | Description         |
|-------|-----------------|---------|---------------------|
| GSREN | "false", "true" | "false" | Enable global reset |
| LSREN | "false", "true" | "true"  | Enable local reset  |

### **Connection Rule**

Q can directly connect to OBUF, or connect to input port DI in IODELAY module;

#### **Primitive Instantiation**

The primitive can be instantiated directly, or generated by the IP Core Generator tool. For more information, you can refer to 5 IP Generation.

### **Verilog Instantiation:**

OSER16 uut(
.Q(Q),
.D0(D0),
.D1(D1),

UG289-1.7E 87(116)

```
.D2(D2),
      .D3(D3),
      .D4(D4),
      .D5(D5),
      .D6(D6),
      .D7(D7),
      .D8(D8),
      .D9(D9),
      .D10(D10),
      .D11(D11),
      .D12(D12),
      .D13(D13),
      .D14(D14),
      .D15(D15),
      .PCLK(PCLK),
      .FCLK(FCLK),
      .RESET(RESET)
  );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
Vhdl Instantiation:
  COMPONENT OSER16
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true"
         );
       PORT(
          Q:OUT std_logic;
          D0:IN std_logic;
                D1:IN std_logic;
                D2:IN std_logic;
                D3:IN std_logic;
                D4:IN std_logic;
                D5:IN std_logic;
                D6:IN std_logic;
                D7:IN std_logic;
```

UG289-1.7E 88(116)

```
D8:IN std_logic;
             D9:IN std_logic;
             D10:IN std_logic;
             D11:IN std_logic;
             D12:IN std_logic;
             D13:IN std_logic;
             D14:IN std_logic;
             D15:IN std_logic;
             FCLK:IN std_logic;
             PCLK:IN std_logic;
       RESET:IN std_logic
    );
END COMPONENT;
uut:OSER16
   GENERIC MAP (GSREN=>"false",
                      LSREN=>"true"
     )
   PORT MAP (
          Q=>Q,
          D0=>D0.
          D1=>D1,
          D2=>D2,
          D3=>D3,
          D4=>D4,
          D5=>D5,
          D6=>D6,
          D7=>D7,
          D8=>D8,
          D9=>D9.
          D10=>D10,
          D11=>D11,
          D12=>D12,
          D13=>D13,
          D14=>D14,
          D15=>D15,
```

UG289-1.7E 89(116)

```
FCLK=>FCLK,
PCLK=>PCLK,
RESET=>RESET
);
```

### **4.3.8 ODDR MEM**

#### **Primitive Introduction**

The Dual Data Rate Output with Memory (ODDR\_MEM) realizes double data rate output with memory.

### **Devices Supported**

Table 4-40 ODDR\_MEM Devices Supported

| Product Family | Series | Device                               |
|----------------|--------|--------------------------------------|
| Arora          | GW2A   | GW2A-18, GW2A-18C, GW2A-55, GW2A-55C |
|                | GW2AN  | GW2AN-55C                            |
|                | GW2AR  | GW2AR-18,GW2AR-18C                   |
|                | GW2ANR | GW2ANR-18C                           |

### **Functional Description**

ODDR\_MEM mode is used for transferring double data rate signals from FPGA devices. Unlike ODDR, the output double data rate with memory (ODDR\_MEM) needs to be used with DQS. TCLK connects to the DQSW0 or DQSW270 of DQS output signal, and outputs data from ODDR\_MEM according to the TCLK clock edge. Where Q0 is the double rate data output, Q1 is used for the OEN signal of IOBUF/TBUF connected to Q0. Its logic diagram is as shown in Figure 4-28.

Figure 4-28 ODDR\_MEM Logic Diagram



The frequency relation between PCLK and TCLK is  $f_{\it PCLK} = f_{\it TCLK}$  .

You can determine the phase relationship between PCLK and TCLK according to DLLSTEP and WSTEP value of DQS.

UG289-1.7E 90(116)

# **Port Diagram**

Figure 4-29 ODDR\_MEM Port Diagram



# **Port Description**

Table 4-41 ODDR\_MEM Port Description

| Port Name | I/O    | Description                                                                                                                         |
|-----------|--------|-------------------------------------------------------------------------------------------------------------------------------------|
| D1~D0     | Input  | ODDR_MEM data input signal                                                                                                          |
| TX        | Input  | Q1 generated by TRI-MDDRX1                                                                                                          |
| TCLK      | Input  | Clock input signal from DQSW0 or DQSW270 in DQS module                                                                              |
| PCLK      | Input  | Primary clock input signal                                                                                                          |
| RESET     | Input  | Asynchronous reset input signal, active-high.                                                                                       |
| Q0        | Output | ODDR_MEM data output signal                                                                                                         |
| Q1        | Output | ODDR_MEM tristate enable control data output can<br>be connected to the IOBUF/TBUF OEN signal<br>connected to Q0, or left floating. |

# **Parameters Description**

Table 4-42 ODDR\_MEM Parameter Description

| Name        | Value                | Default | Description                                                                                                                      |
|-------------|----------------------|---------|----------------------------------------------------------------------------------------------------------------------------------|
| GSREN       | "false", "true"      | "false" | Enable global reset                                                                                                              |
| LSREN       | "false", "true"      | "true"  | Enable local reset                                                                                                               |
| TXCLK_POL   | 1'b0, 1'b1           | 1'b0    | <ul> <li>Q1 output clock polarity control</li> <li>1'b0: data posedge output</li> <li>1'b1: data negedge output</li> </ul>       |
| TCLK_SOURCE | "DQSW",<br>"DQSW270" | "DQSW"  | TCLK source selection  TCLK source selection  DQSW" comes from DQSW0 in DQS module  TDQSW270" comes from DQSW270 from DQS module |

UG289-1.7E 91(116)

#### **Connection Rule**

- Q0 can directly connect to OBUF, or connect to input port DI in IODELAY module;
- Q1 shall connect to the OEN signal of IOBUF/TBUF connected to Q0, or left floating.
- TCLK needs DQSW0 or DQSW270 from DQS module and you need to configure the corresponding parameters.

#### **Primitive Instantiation**

### Verilog Instantiation:

```
ODDR_MEM oddr_mem_inst(
      .Q0(q0),
      .Q1(q1),
      .D0(d0),
      .D1(d1),
      .TX(tx),
      .TCLK(tclk),
      .PCLK(pclk),
      .RESET(reset)
  );
 defparam uut.GSREN="false";
 defparam uut.LSREN ="true";
 defparam uut.TCLK_SOURCE ="DQSW";
 defparam uut.TXCLK_POL=1'b0;
VhdI Instantiation:
  COMPONENT ODDR_MEM
       GENERIC (GSREN:string:="false";
                    LSREN:string:="true";
                    TXCLK_POL:bit:='0';
                    TCLK_SOURCE:string:="DQSW"
         );
       PORT(
          Q0:OUT std_logic;
               Q1:OUT std logic;
          D0:IN std_logic;
               D1:IN std_logic;
               TX:IN std_logic;
```

UG289-1.7E 92(116)

```
TCLK:IN std_logic;
             PCLK:IN std_logic;
             RESET:IN std_logic
   );
END COMPONENT;
uut:ODDR_MEM
   GENERIC MAP (GSREN=>"false",
                      LSREN=>"true",
                      TXCLK POL=>'0',
                      TCLK_SOURCE=>"DQSW"
     )
   PORT MAP (
          Q0 = > q0,
          Q1 = > q1,
          D0 = > d0.
          D1 = > d1
          TX = >tx,
          TCLK=>tclk,
          PCLK=>pclk,
          RESET=>reset
    );
```

### **4.3.9 OSER4 MEM**

#### **Primitive Introduction**

4 to 1 Serializer with Memory (OSER4\_MEM) realizes 4:1 parallel serial conversion with memory.

### **Devices Supported**

Table 4-43 OSER4\_MEM Devices Supported

| Product Family | Series | Device                               |
|----------------|--------|--------------------------------------|
| Arora          | GW2A   | GW2A-18, GW2A-18C, GW2A-55, GW2A-55C |
|                | GW2AN  | GW2AN-55C                            |
|                | GW2AR  | GW2AR-18,GW2AR-18C                   |
|                | GW2ANR | GW2ANR-18C                           |

### **Functional Description**

OSER4\_MEM realizes 4:1 parallel serial conversion. The TCLK connects to the output signal DQSW0 or DQSW270 of DQS, and outputs

UG289-1.7E 93(116)

data from the OSER4\_MEM according to the TCLK clock edge, and Q0 is the serial output, Q1 is used for the OEN signal of IOBUF/TBUF connected to Q0. Its logic diagram is as shown in Figure 4-30.

Figure 4-30 OSER4\_MEM Logic Diagram



The frequency relation among PCLK, FCLK and TCLK is  $f_{\it PCLK} = 1/2\,f_{\it FCLK} = 1/2\,f_{\it TCLK}$ 

You can determine the phase realationship between FCLK and TCLK according to the DLLSTEP and WSTEP values of DQS.

### **Port Diagram**

Figure 4-31 OSER4\_MEM Diagram



UG289-1.7E 94(116)

# **Port Description**

# Table 4-44 OSER4\_MEM Port Description

| Port Name | I/O    | Description                                                                                                                    |  |
|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------|--|
| D3~D0     | Input  | OSER4_MEM data input signal                                                                                                    |  |
| TX1~TX0   | Input  | Q1 generated by TRI-MDDRX2                                                                                                     |  |
| TCLK      | Input  | Clock input signal from DQSW0 or DQSW270 in DQS module                                                                         |  |
| FCLK      | Input  | High speed clock input signal                                                                                                  |  |
| PCLK      | Input  | Primary clock input signal                                                                                                     |  |
| RESET     | Input  | Asynchronous reset input signal, active-high.                                                                                  |  |
| Q0        | Output | OSER4_MEM data output signal                                                                                                   |  |
| Q1        | Output | OSER4_MEM tristate enable control data output can be connected to the IOBUF/TBUF OEN signal connected to Q0, or left floating. |  |

# **Parameters Description**

## Table 4-45 OSER4\_MEM Parameter Description

| Name        | Value            | Default  | Description                                                                                                                                             |
|-------------|------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| GSREN       | "false", "true"  | "false"  | Enable global reset                                                                                                                                     |
| LSREN       | "false", "true"  | "true"   | Enable local reset                                                                                                                                      |
| TXCLK_POL   | 1'b0, 1'b1       | 1'b0     | Q1 output clock polarity control  1'b0: data posedge output  1'b1: data negedge output                                                                  |
| TCLK_SOURCE | "DQSW","DQSW270" | " DQSW " | TCLK source selection  IDQSW" comes from DQSW0 in DQS module  IDQSW270" comes from DQSW270 from DQS module                                              |
| HWL         | "false", "true"  |          | OSER4_MEM data d_up0/1 timing relationship control      "False ": d_up1 is one cycle ahead of d_up0;      "True ": d_up1 and d_up0 have the same timing |

UG289-1.7E 95(116)

#### **Connection Rule**

- Q0 can directly connect to OBUF, or connect to input port DI in IODELAY module;
- Q1 shall connect to the OEN signal of IOBUF/TBUF connected to Q0, or suspend.
- TCLK needs DQSW0 or DQSW270 from DQS module and you need to configure the corresponding parameters.

#### **Primitive Instantiation**

### **Verilog Instantiation:**

```
OSER4_MEM oser4_mem_inst(
       .Q0(q0),
       .Q1(q1),
       .D0(d0),
       .D1(d1),
       .D2(d2),
       .D3(d3),
       .TX0(tx0),
       .TX1(tx1),
       .TCLK (tclk),
       .FCLK (fclk),
       .PCLK (pclk),
       .RESET(reset)
  );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
  defparam uut.HWL ="false";
  defparam uut.TCLK_SOURCE ="DQSW";
  defparam uut.TXCLK_POL=1'b0;
VhdI Instantiation:
  COMPONENT OSER4_MEM
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true";
                     HWL:string:="false";
                     TXCLK_POL:bit:='0';
                     TCLK_SOURCE:string:="DQSW"
         );
```

UG289-1.7E 96(116)

```
PORT(
        Q0:OUT std_logic;
             Q1:OUT std_logic;
        D0:IN std_logic;
             D1:IN std_logic;
             D2:IN std_logic;
             D3:IN std_logic;
             TX0:IN std_logic;
             TX1:IN std_logic;
             TCLK:IN std_logic;
             FCLK:IN std_logic;
             PCLK:IN std_logic;
             RESET:IN std_logic
   );
END COMPONENT:
uut:OSER4_MEM
    GENERIC MAP (GSREN=>"false",
                       LSREN=>"true",
                       HWL=>"false",
                       TXCLK_POL=>'0',
                       TCLK_SOURCE=>"DQSW"
     )
    PORT MAP (
          Q0 = > q0,
          Q1 = > q1,
          D0 = > d0,
          D1 = > d1,
          D2 = > d2,
          D3 = > d3.
          TX0=>tx0,
          TX1=>tx1,
          TCLK=>tclk,
          FCLK=>fclk,
          PCLK=>pclk,
          RESET=>reset
```

UG289-1.7E 97(116)

);

#### **4.3.10 OSER8 MEM**

#### **Primitive Introduction**

8 to 1 Serializer with Memory (OSER8\_MEM) realizes 8:1 parallel serial conversion with memory.

#### **Devices Supported**

Table 4-46 OSER8\_MEM Devices Supported

| Product Family | Series | Device                               |
|----------------|--------|--------------------------------------|
| Arora          | GW2A   | GW2A-18, GW2A-18C, GW2A-55, GW2A-55C |
|                | GW2AN  | GW2AN-55C                            |
|                | GW2AR  | GW2AR-18,GW2AR-18C                   |
|                | GW2ANR | GW2ANR-18C                           |

#### **Functional Description**

OSER8\_MEM mode realizes 8:1 parallel serial conversion. The TCLK connects the output signal DQSW0 or DQSW270 of DQS, and outputs data from the OSER8\_MEM according to the TCLK clock edge, and Q0 is the serial output, Q1 is used for the OEN signal of IOBUF/TBUF connected to Q0. Its logic diagram is as shown in Figure 4-32.

Figure 4-32 OSER8\_MEM Logic Diagram



The frequency relation between PCLK, FCLK and TCLK is  $f_{PCLK} = 1/4\,f_{FCLK} = 1/4\,f_{TCLK}$ 

UG289-1.7E 98(116)

You can determine the phase realationship between FCLK and TCLK according to DLLSTEP and WSTEP values of DQS.

#### **Port Diagram**

Figure 4-33 OSER8\_MEM Port Diagram



#### **Port Description**

Table 4-47 OSER4\_MEM Port Description

| Port Name | I/O    | Description                                                                                                                    |
|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------|
| D7~D0     | Input  | OSER8_MEM data input signal                                                                                                    |
| TX3~TX0   | Input  | Q1 generated by TRI-MDDRX4                                                                                                     |
| TCLK      | Input  | Clock input signal from DQSW0 or DQSW270 in DQS module                                                                         |
| FCLK      | Input  | High speed clock input signal                                                                                                  |
| PCLK      | Input  | Primary clock input signal                                                                                                     |
| RESET     | Input  | Asynchronous reset input signal, active-high.                                                                                  |
| Q0        | Output | OSER8_MEM data output signal                                                                                                   |
| Q1        | Output | OSER8_MEM tristate enable control data output can be connected to the IOBUF/TBUF OEN signal connected to Q0, or left floating. |

## **Parameter Description**

Table 4-48 OSER4\_MEM Parameter Description

| Name      | Value           | Default | Description                                                                            |
|-----------|-----------------|---------|----------------------------------------------------------------------------------------|
| GSREN     | "false", "true" | "false" | Enable global reset                                                                    |
| LSREN     | "false", "true" | "true"  | Enable Local Reset                                                                     |
| TXCLK_POL | 1'b0, 1'b1      | 1'b0    | Q1 output clock polarity control  1'b0: data posedge output  1'b1: data negedge output |

UG289-1.7E 99(116)

| Name        | Value            | Default  | Description                                                                                                                                       |
|-------------|------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| TCLK_SOURCE | "DQSW","DQSW270" | " DQSW " | TCLK source selection  IDQSW" comes from DQSW0 in DQS module  IDQSW270" comes from DQSW270 from DQS module                                        |
| HWL         | "false", "true"  | "false"  | OSER8_MEM data d_up0/1 timing relationship control • "false ": d_up1 is one cycle ahead of d_up0; • "true ": d_up1 and d_up0 have the same timing |

#### **Connection Rule**

- Q0 can directly connect to OBUF, or connect to input port DI in IODELAY module.
- Q1 shall connect to the OEN signal of IOBUF/TBUF connected to Q0, or left floating.
- TCLK needs DQSW0 or DQSW270 from DQS module and you need to configure the corresponding parameters.

#### **Primitive Instantiation**

### **Verilog Instantiation:**

OSER8\_MEM oser8\_mem\_inst(

- .Q0(q0),
- .Q1(q1),
- .D0(d0),
- .D1(d1),
- .D2(d2),
- .D3(d3),
- .D4(d4),
- .D5(d5),
- .D6(d6),
- .D7(d7),
- .TX0(tx0),
- .TX1(tx1),
- .TX2(tx2),

UG289-1.7E 100(116)

```
.TX3(tx3),
        .TCLK (tclk),
        .FCLK (fclk),
        .PCLK (pclk),
        .RESET(reset)
  );
  defparam uut.GSREN="false";
  defparam uut.LSREN ="true";
  defparam uut.HWL ="false";
  defparam uut.TCLK_SOURCE ="DQSW";
  defparam uut.TXCLK_POL=1'b0;
VhdI Instantiation:
  COMPONENT OSER8 MEM
       GENERIC (GSREN:string:="false";
                     LSREN:string:="true";
                     HWL:string:="false";
                     TXCLK_POL:bit:='0';
                     TCLK_SOURCE:string:="DQSW"
         );
       PORT(
          Q0:OUT std_logic;
                Q1:OUT std_logic;
          D0:IN std_logic;
                D1:IN std_logic;
                D2:IN std_logic;
                D3:IN std_logic;
                D4:IN std_logic;
                D5:IN std_logic;
                D6:IN std_logic;
                D7:IN std_logic;
                TX0:IN std_logic;
                TX1:IN std_logic;
                TX2:IN std_logic;
                TX3:IN std_logic;
                TCLK:IN std_logic;
```

UG289-1.7E 101(116)

```
FCLK:IN std_logic;
             PCLK:IN std_logic;
             RESET:IN std_logic
   );
END COMPONENT;
uut:OSER8_MEM
    GENERIC MAP (GSREN=>"false",
                       LSREN=>"true",
                       HWL=>"false",
                       TXCLK_POL=>'0',
                       TCLK_SOURCE=>"DQSW"
     )
    PORT MAP (
          Q0 = > q0,
          Q1 = > q1,
          D0 = > d0
          D1 = > d1,
          D2 = > d2,
          D3 = > d3,
          D4 = > d4,
          D5=>d5,
          D6 = > d6
          D7 = > d7,
          TX0 = > tx0,
          TX1=>tx1,
          TX2 = > tx2
          TX3 = > tx3,
          TCLK=>tclk,
          FCLK=>fclk,
          PCLK=>pclk,
          RESET=>reset
     );
```

UG289-1.7E 102(116)

# 4.4 Delay Module

#### 4.4.1 IODELAY

#### **Primitive Introduction**

Input/Output delay (IODELAY) is a programmable delay unit in IO module.

#### **Functional Description**

Each IO contains an IODELAY module, providing a total of 128 (0~127) delays. The GW1N series of FPGA has a single-step delay time of about 30ps. And the GW2A series of FPGA has a single-step delay time of about 18ps. IODELAY can be used for input or output of I/O logic, but not for both at the same time.

#### **Port Diagram**

Figure 4-34 IODELAY Port Diagram



#### **Port Description**

**Table 4-49 IODELAY Port Description** 

| Port Name | I/O    | Description                                                                                    |  |
|-----------|--------|------------------------------------------------------------------------------------------------|--|
| DI        | Input  | Data input signal                                                                              |  |
| SDTAP     | Input  | Controls loading static delay step  0: loads static delay  1: adjusts the dynamic delay        |  |
| SETN      | Input  | Sets the direction of dynamic delay adjustment                                                 |  |
| VALUE     | Input  | VALUE is the delay value of negedge dynamic adjustment, and it moves one delay step per pulse. |  |
| DO        | Output | Data output signal                                                                             |  |
| DF        | Output | An output flag that represents under-flow or over-flow in dynamic delay adjustment             |  |

UG289-1.7E 103(116)

#### **Parameters Description**

**Table 4-50 IODELAY Parameter Description** 

| Name         | Value | Default | Description                    |
|--------------|-------|---------|--------------------------------|
| C_STATIC_DLY | 0~127 | 0       | Controls the static delay step |

#### **Primitive Instantiation**

```
Verilog Instantiation:
```

```
IODELAY iodelay_inst(
     .DO(dout),
     .DF(df),
     .DI(di),
     .SDTAP(sdtap),
     .SETN(setn),
     .VALUE(value)
  );
  defparam iodelay_inst.C_STATIC_DLY=0;
Vhdl Instantiation:
  COMPONENT IODELAY
       GENERIC (C_STATIC_DLY:integer:=0
         );
       PORT(
          DO:OUT std_logic;
               DF:OUT std_logic;
          DI:IN std_logic;
               SDTAP:IN std_logic;
               SETN:IN std_logic;
               VALUE: IN std_logic
        );
  END COMPONENT;
  uut:IODELAY
      GENERIC MAP (C_STATIC_DLY=>0
        )
      PORT MAP (
            DO=>dout,
            DF=>df,
```

UG289-1.7E 104(116)

```
DI=>di,
SDTAP=>sdtap,
SETN=>setn,
VALUE=>value
);
```

#### 4.4.2 IODELAYC

#### **Primitive Introduction**

Input/Output delay (IODELAY) is a programmable delay unit in IO module.

#### **Devices Supported**

**Table 4-51 IODELAYC Devices Supported** 

| Product Family         | Series | Device   |
|------------------------|--------|----------|
| LittleBee <sup>®</sup> | GW1N   | GW1N-9C  |
| Littlebee              | GW1NR  | GW1NR-9C |

#### **Functional Description**

Each IO contains the IODELAYC module, which provides a total of 128 (0 to 127) delay, adding more delay adjustments compared to IODELAY. IODELAYC can be used for I/O logic input.

#### **Port Diagram**

Figure 4-35 IODELAYC Port Diagram



#### **Port Description**

**Table 4-52 IODELAYC Port Description** 

| Port Name | I/O   | Description                                                                               |  |
|-----------|-------|-------------------------------------------------------------------------------------------|--|
| DI        | Input | Data input signal                                                                         |  |
| SDTAP     | Input | Controls loading static delay step  0: loads static delay  1: adjusts the dynamical delay |  |

UG289-1.7E 105(116)

| Port Name  | I/O    | Description                                                                                     |  |
|------------|--------|-------------------------------------------------------------------------------------------------|--|
| SETN       | Input  | Sets the direction of dynamical delay adjustment      0: Increases delay     1: Decreases delay |  |
| VALUE      | Input  | VALUE is the delay value of negedge dynamical adjustment, and each pulse moves one delay step.  |  |
| DASEL[1:0] | Input  | Dynamically controls DAO delay mode                                                             |  |
| DAADJ[1:0] | Input  | Dynamically controls the delay value of the DAO relative to the DO.                             |  |
| DO         | Output | Data output signal                                                                              |  |
| DAO        | Output | Output signal of data delay adjustment                                                          |  |
| DF         | Output | An output flag that represents under-flow or over-flow in dynamical delay adjustment.           |  |

#### **Parameter Description**

**Table 4-53 IODELAYC Parameter Description** 

| Name         | Value              | Default | Description                                                                                                                                                                                             |
|--------------|--------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_STATIC_DLY | 0~127              | 0       | Controls the static delay step                                                                                                                                                                          |
| DYN_DA_SEL   | "True"/<br>"false" | false   | <ul> <li>false: selects parameter         DA_SEL to statically control         DAO delay mode.</li> <li>true: selects the signal DASEL         to dynamically control DAO         delay mode</li> </ul> |
| DA_SEL       | 2'b00~2'b11        | 2'b00   | Static control of DAO delay mode                                                                                                                                                                        |

#### **Primitive Instantiation**

#### **Verilog Instantiation:**

UG289-1.7E 106(116)

```
defparam iodelayc_inst.DYN_DA_SEL="true";
  defparam iodelayc inst.DA SEL=2'b01;
VhdI Instantiation:
  COMPONENT IODELAYC
       GENERIC (C_STATIC_DLY:integer:=0;
             DYN_DA_SEL:string:="false";
             DA_SEL:bit_vector:="00"
        );
       PORT(
          DO:OUT std_logic;
          DAO:OUT std_logic;
               DF:OUT std_logic;
          DI:IN std_logic;
               SDTAP:IN std_logic;
               SETN:IN std_logic;
               VALUE: IN std_logic;
          DASEL: IN std_logic_vector(1 downto 0);
              DAADJ: IN std_logic_vector(1 downto 0)
        );
  END COMPONENT;
  uut:IODELAYC
      GENERIC MAP (C_STATIC_DLY=>0,
               DYN_DA_SEL=>"true",
               DA_SEL=>"01"
        )
      PORT MAP (
            DO=>dout,
            DAO=>dout,
            DF=>df,
            DI=>di,
            SDTAP=>sdtap,
            SETN=>setn,
            VALUE=>value,
        DASEL=>dasel,
        DAADJ=>daadj
```

UG289-1.7E 107(116)

);

#### **4.4.3 IODELAYB**

#### **Primitive Introduction**

Input/Output delay (IODELAYB) is a programmable delay unit in IO module.

#### **Devices Supported**

**Table 4-54 Devices Supported** 

| Family                 | Series | Device  |
|------------------------|--------|---------|
| LittleBee <sup>®</sup> | GW1N   | GW1N-2  |
|                        | GW1NZ  | GW1NZ-2 |
|                        | GW1NR  | GW1NR-2 |

#### **Functional Description**

Each IO contains the IODELAYB module, which provides a total of 128 (0 to 127) delay. IODELAYB adds more delay adjustments compared to IODELAY. IODELAYB can be used for I/O logic input, and the diagram is as shown in Figure 4-36.

Figure 4-36 IODELAYB Diagram



UG289-1.7E 108(116)

## **Port Diagram**

Figure 4-37 IODELAYB Port Diagram



# **Port Description**

**Table 4-55 IODELAYB Port Description** 

| Port Name  | I/O    | Description                                                                                    |  |
|------------|--------|------------------------------------------------------------------------------------------------|--|
| DI         | Input  | Data input signal                                                                              |  |
| SDTAP      | Input  | Controls loading static delay step  ■ 0: loads static delay                                    |  |
|            |        | 1: adjusts the dynamical delay                                                                 |  |
| SETN       | Input  | Sets the direction of dynamical delay adjustment  O: Increases delay  1: Decreases delay       |  |
| VALUE      | Input  | VALUE is the delay value of negedge dynamical adjustment, and each pulse moves one delay step. |  |
| DAADJ[1:0] | Input  | Dynamically controls the delay value of the DAO relative to the DO                             |  |
| DO         | Output | Data output signal                                                                             |  |
| DAO        | Output | Output signal of data delay adjustment                                                         |  |
| DF         | Output | An output flag that represents under-flow or over-flow in dynamical delay adjustment           |  |

# **Parameter Description**

Table 4-56 IODELAYB Parameter Description

| Name         | Value       | Default | Description                                                                                         |  |
|--------------|-------------|---------|-----------------------------------------------------------------------------------------------------|--|
| C_STATIC_DLY | 0~127       | 0       | Controls Static delay step                                                                          |  |
| DELAY_MUX    | 2'b00~2'b11 | 2'b00   | Delay MUX selects 2'b00:dmux_o=DI; 2'b01:#100ps dmux_o=DI; 2'b10:dmux_o=dlyout_mid; 2'b11:dmux_o=DO |  |

UG289-1.7E 109(116)

| Name   | Value       | Default | Description                      |
|--------|-------------|---------|----------------------------------|
| DA_SEL | 2'b00~2'b11 | 2'b00   | DAO delay mode in static control |

#### Note!

When IODELAYB used, the connection of parameters DELAY\_MUX and DA\_SEL are as follows:

- DELAY\_MUX:2/3 -> DA\_SEL:0/1. When DELAY\_MUX is 2 or 3, DA\_SEL can be 0 or 1;
- DELAY\_MUX:0/1 -> DA\_SEL:0/2/3. When DELAY\_MUX is 0 or 1, DA\_SELcan be 0, 2 or 3.

#### **Connection Rule**

DO can not connect to IDDR/IDES, and DAO can only connect to data input of IDDR/IDES.

#### **Primitive Instantiation**

#### **Verilog Instantiation:**

```
IODELAYB iodelayb_inst(
     .DO(dout),
     .DAO(douta),
     .DF(df),
     .DI(di),
     .SDTAP(sdtap),
     .SETN(setn),
     .VALUE(value),
     .DAADJ(daadj)
  );
  defparam iodelayb_inst.C_STATIC_DLY=0;
  defparam iodelayb_inst. DELAY_MUX = 2'b00;
  defparam iodelayb_inst.DA_SEL=2'b00;
VhdI Instantiation:
  COMPONENT IODELAYB
       GENERIC (C_STATIC_DLY:integer:=0;
             DELAY_MUX : bit_vector := "00";
             DA SEL:bit vector:= "00"
         );
       PORT(
          DO:OUT std_logic;
          DAO:OUT std_logic;
                DF:OUT std_logic;
```

UG289-1.7E 110(116)

4 Input/Output Logic 4.5 IEM

```
DI:IN std_logic;
             SDTAP:IN std_logic;
             SETN:IN std_logic;
             VALUE: IN std_logic;
           DAADJ : IN std_logic_vector(1 downto 0)
     );
END COMPONENT;
uut:IODELAYB
   GENERIC MAP (C STATIC DLY=>0,
            DELAY_MUX =>"00",
            DA SEL=>"00"
     )
   PORT MAP (
         DO=>dout,
          DAO=>douta.
          DF=>df,
          DI=>di,
          SDTAP=>sdtap,
          SETN=>setn,
          VALUE=>value.
     DAADJ=>daadj
    );
```

# **4.5 IEM**

#### **Primitive Introduction**

Input Edge Monitor (IEM) is a sampling module in IO module.

#### **Functional Description**

IEM is used for sampling data edge, which can be used together with delay module to adjust the dynamic sampling window for DDR mode.

UG289-1.7E 111(116)

4 Input/Output Logic 4.5 IEM

#### **Port Diagram**

Figure 4-38 IEM Port Diagram



#### **Port Description**

**Table 4-57 IEM Port Description** 

| Port Name | I/O    | Description                                                |
|-----------|--------|------------------------------------------------------------|
| D         | Input  | Data input signal                                          |
| CLK       | Input  | Clock input signal                                         |
| RESET     | Input  | Asynchronous reset input signal, active-high.              |
| MCLK      | Input  | IEM detecting clock, from user logic, acts on output flag. |
| LAG       | Output | The output flag of IEM edge compared with LAG              |
| LEAD      | Output | The output flag of IEM edge compared with LEAD             |

#### **Parameter Description**

**Table 4-58 IEM Parameter Description** 

| Name    | Value                                     | Default | Description         |
|---------|-------------------------------------------|---------|---------------------|
| WINSIZE | "SMALL","MIDSMALL",<br>"MIDLARGE","LARGE" | "SMALL" | Window size setting |
| GSREN   | "false", "true"                           | "false" | Enable global reset |
| LSREN   | "false", "true"                           | "true"  | Enable local reset  |

#### **Primitive Instantiation**

#### **Verilog Instantiation:**

IEM iem\_inst(
.LAG(lag),
.LEAD(lead),
.D(d),
.CLK(clk),
.MCLK(mclk),
.RESET(reset)

UG289-1.7E 112(116)

4 Input/Output Logic 4.5 IEM

```
);
  defparam iodelay_inst.WINSIZE = "SMALL";;
  defparam iodelay_inst.GSREN = "false";
  defparam iodelay_inst.LSREN = "true";
VhdI Instantiation:
  COMPONENT IEM
       GENERIC (WINSIZE:string:="SMALL";
                    GSREN:string:="false";
                    LSREN:string:="true"
         );
       PORT(
          LAG:OUT std_logic;
               LEAD:OUT std_logic;
                D:IN std_logic;
               CLK:IN std_logic;
               MCLK:IN std_logic;
               RESET:IN std_logic
      );
  END COMPONENT;
  uut:IEM
      GENERIC MAP (WINSIZE=>"SMALL",
                        GSREN=>"false",
                        LSREN=>"true"
        )
      PORT MAP (
            LAG=>lag,
            LEAD=>lead,
            D=>d,
            CLK=>clk,
            MCLK=>mclk,
            RESET=>reset
       );
```

UG289-1.7E 113(116)

5 IP Generation 5.1 IP Configuration

# **5** IP Generation

The software only supports DDR at present. Click DDR in the IP Core Generator interface, and a summary of DDR will be displayed on the right side of the interface.

# 5.1 IP Configuration

Double-click "DDR", and the "IP Customization" window pops up. This includes the "File", "Options", port diagram, and "Help", as shown in Figure 5-1.

W IP Customization  $\times$ **DDR** GW2A-55 Part Number: GW2A-LV55PG1156C8/I7 Create In: D:\8bit\_counter\src\gowin\_ddr Module Name: Gowin\_DDR ▼ Synthesis Tool: GowinSynthesis Options din[0:0] DDR Mode: Input + Data Width: 1 Reset IODEL AV Delay Mode: None Delay Direction: Input Delay Step: Use CLKDIV थ् Cancel

Figure 5-1 IP Customization of DDR

1. File

The File configuration box is used to configure the generated IP design

UG289-1.7E 114(116)

5 IP Generation 5.1 IP Configuration

file.

- Device: Displays the configured Device.
- Part Number: Displays the configured Part Number.
- Language: Hardware description language used to generate the IP design files. Click the drop-down list to select the language, including Verilog and VHDL.
- Synthesis Tool: Selects synthesis tools.
- Module Name: The module name of the generated IP design files. Enter the module name in the text box. Module name cannot be the same as the primitive name. If it is the same, an error will be reported.
- File Name: The name of the generated IP design files. Enter the file name in the text box.
- Create In: The path in which the generated IP files will be stored.
   Enter the target path in the box or select the target path by clicking the option.

#### 2. Options

The Options configuration box is used to customize the IP, as shown Figure 5-1.

- DDR Mode: Configures DDR mode, including input, output, tristate and bi-directional state;
- Data Width: Configures the data width of the DDR. The range is 1~64;
- Ratio: DDR data conversion ratio, including 2,4,7,8,10,16;
- Reset: When Ratio is 2, this option can be enabled or disabled, and IDDRC or ODDRC will be instantiated when enabled;
- IODELAY: Configures whether DDR uses a delay module;
  - "Delay Mode": Configures the delay mode. "None" means no IODELAY; "Dynamic" means using IODELAY and adjusting the delay step dynamically; "Static" means using IODELAY and adjusting the delay step statically.
  - "Delay Step": Selects the number of steps to statically adjust the delay, ranging 1 to 128.
  - "Delay Direction": In bidirectional mode, When DDR Mode is "bidirectional", if IODELAY is used, select whether IODELAY is connected to input or output.
- Use CLKDIV: CLKDIV will be instantiated and the frequency of fclk will be divided when CLKDIV is enabled. When Ratio is 2, it cannot be checked.

#### Port Diagram

The port diagram displays a sample diagram of IP Core configuration, as shown in Figure 5-1.

UG289-1.7E 115(116)

5 IP Generation 5.2 IP Generated Files

#### 4. Help

Click "Help" to open the IP Core configuration information. The Help page includes an overview of IP Core and a brief description of the configuration of options.

# 5.2 IP Generated Files

After configuration, it will generate three files that are named after the "File Name".

- The IP design file "gowin\_ddr.v" is a complete verilog module, which generates DDR modules with corresponding functions according to the configuration.
- "Gowin\_ddr\_tmp.v" is the template file;
- "gowin\_padd.ipc" file is IP configuration file. You can load the file to configure the IP.

#### Note!

If VHDL is selected as the hardware description language, the first two files will be named with .vhd suffix.

UG289-1.7E 116(116)

